@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@700&display=swap";.share-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.share-modal{background:#0f0f23f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;width:90%;max-width:520px;min-width:320px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000080;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.share-modal-header{padding:20px;border-top:none;border-bottom:1px solid rgba(255,255,255,.08);position:relative}.share-modal-header h2{margin:0 0 4px;font-size:18px;font-weight:800;color:#fff}.share-modal-header .item-name{font-size:14px;color:#ffffff80}.share-modal-header .close-btn{position:absolute;top:16px;right:16px;background:none;border:none;padding:4px;cursor:pointer;color:#fff6;border-radius:6px;transition:all .2s}.share-modal-header .close-btn:hover{background:#ffffff14;color:#fff}.share-tabs{display:flex;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08)}.share-tabs .tab{flex:1;padding:12px 16px;background:none;border:none;font-size:13px;font-weight:500;color:#ffffff73;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.share-tabs .tab:hover{background:#ffffff0f;color:#ffffffb3}.share-tabs .tab.active{color:#06b6d4;border-bottom-color:#06b6d4;background:#06b6d40f}.share-content{padding:20px}.invite-form{display:flex;flex-direction:column;gap:12px}.invite-input{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:14px;background:#ffffff0f;color:#fff;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.invite-input::placeholder{color:#ffffff4d}.invite-input:focus{outline:none;border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d426}.role-selector{display:flex;align-items:center;gap:12px}.role-selector label{font-size:13px;color:#ffffffa6;font-weight:600}.role-selector select{flex:1;padding:8px 12px;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:13px;background:#ffffff0f;color:#fff;cursor:pointer}.role-selector select option{background:#1a1a2e;color:#fff}.invite-btn,.create-link-btn{padding:10px 16px;border:none;border-radius:10px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#22c55e,#06b6d4)}.invite-btn:hover:not(:disabled),.create-link-btn:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 15px #06b6d44d}.invite-btn:disabled,.create-link-btn:disabled{opacity:.5;cursor:not-allowed}.link-section{display:flex;flex-direction:column;gap:12px}.link-section p{font-size:13px;color:#ffffff80;margin:0}.share-link-display{display:flex;gap:8px}.link-input{flex:1;padding:10px 12px;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:12px;background:#ffffff0a;color:#ffffffb3}.copy-btn{padding:10px 16px;background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.copy-btn:hover{filter:brightness(1.1);box-shadow:0 4px 15px #06b6d44d}.error-message{padding:10px 12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#f87171;font-size:13px;margin-top:12px}.success-message{padding:10px 12px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:10px;color:#4ade80;font-size:13px;margin-top:12px}.collaborators-section{border-top:1px solid rgba(255,255,255,.08);padding:16px 20px}.collaborators-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#ffffffa6}.collaborators-list{display:flex;flex-direction:column;gap:8px}.collaborator-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px}.collaborator-info{display:flex;align-items:center;gap:10px}.collaborator-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.collaborator-avatar.placeholder{background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#ffffff80}.collaborator-details{display:flex;flex-direction:column}.collaborator-name{font-size:13px;font-weight:500;color:#fff}.pending-badge{font-size:11px;color:#f59e0b;font-weight:500}.collaborator-actions{display:flex;align-items:center;gap:8px}.role-select{padding:4px 8px;border:1px solid rgba(255,255,255,.12);border-radius:6px;font-size:12px;background:#ffffff0f;color:#fff}.role-select option{background:#1a1a2e;color:#fff}.role-badge{font-size:11px;padding:4px 8px;background:#ffffff14;border-radius:6px;color:#fff9;text-transform:capitalize}.remove-btn{padding:4px;background:none;border:none;color:#ffffff4d;cursor:pointer;border-radius:4px;transition:all .2s}.remove-btn:hover{background:#ef444426;color:#ef4444}@media(max-width:480px){.share-modal{width:95%;max-height:85vh}.share-tabs .tab{padding:10px 12px;font-size:12px}.share-content{padding:16px}.role-selector{flex-direction:column;align-items:stretch}.collaborator-item{flex-direction:column;align-items:flex-start;gap:10px}.collaborator-actions{width:100%;justify-content:space-between}}.hierarchy-tree{display:flex;flex-direction:column;height:100%}.tree-header{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:12px}.tree-title{font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.tree-add-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.25);border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.tree-add-btn:hover{background:#22c55e40;border-color:#22c55e66}.tree-search{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;margin-bottom:12px}.tree-search svg{color:#ffffff4d;flex-shrink:0}.tree-search-input{flex:1;border:none;background:transparent;font-size:13px;color:#fff;outline:none}.tree-search-input::placeholder{color:#ffffff4d}.tree-search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;color:#ffffff80;transition:all .15s}.tree-search-clear:hover{background:#ffffff2e;color:#fffc}.tree-clear-search{background:none;border:none;color:#06b6d4;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px}.tree-clear-search:hover{background:#06b6d41a}.login-notice{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:8px;margin-bottom:12px;font-size:12px;color:#fbbf24}.login-notice svg{flex-shrink:0;color:#f59e0b}.tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:#fff6}.tree-empty .empty-icon{color:#ffffff26;margin-bottom:12px}.tree-empty p{margin:0 0 4px;font-size:14px;font-weight:600;color:#ffffffa6}.tree-empty span{font-size:12px}.tree-content{flex:1;overflow-y:auto}.tree-row{display:flex;align-items:center;gap:6px;padding:8px 4px;border-radius:6px;transition:background-color .15s}.tree-row:hover{background-color:#ffffff0f}.house-row{padding-left:0}.collection-row{padding-left:4px}.tree-expand{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#fff6;transition:transform .2s,color .15s;flex-shrink:0}.tree-expand:hover{color:#ffffffb3}.tree-expand.expanded{transform:rotate(90deg)}.tree-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.house-icon{background:#3b82f6}.house-icon img{width:18px;height:18px;object-fit:contain}.collection-icon{background:#ffffff14;color:#ffffff80}.tree-label{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0;cursor:pointer}.tree-name{font-size:13px;font-weight:600;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-count{font-size:11px;color:#fff6}.tree-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.tree-row:hover .tree-actions{opacity:1}.tree-action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:4px;cursor:pointer;color:#ffffff80;transition:all .15s;text-decoration:none}.tree-action-btn:hover{background:#ffffff1f;color:#fffc}.tree-action-btn.view{color:#ffffff80}.tree-action-btn.view:hover{background:#06b6d426;border-color:#06b6d44d;color:#06b6d4}.tree-action-btn.add{background:#22c55e1a;border-color:#22c55e33;color:#22c55e}.tree-action-btn.add:hover{background:#22c55e33;border-color:#22c55e59;color:#4ade80}.tree-action-btn.delete{background:#ef44441a;border-color:#ef444433;color:#ef4444}.tree-action-btn.delete:hover{background:#ef444433;border-color:#ef444459;color:#f87171}.tree-action-btn.delete:disabled{opacity:.5;cursor:not-allowed}.tree-connector{width:20px;height:24px;position:relative;flex-shrink:0}.tree-connector:before{content:"";position:absolute;left:9px;top:0;width:1px;height:100%;background:#ffffff14}.tree-connector:after{content:"";position:absolute;left:9px;top:12px;width:8px;height:1px;background:#ffffff14}.tree-connector.last:before{height:12px}.tree-connector.deep{margin-left:20px}.tree-children{padding-left:10px}.empty-row{padding:6px 4px}.empty-text{font-size:12px;color:#ffffff59;font-style:italic}.tree-inline-add{background:none;border:1px dashed rgba(255,255,255,.12);border-radius:4px;padding:4px 8px;font-size:11px;color:#fff6;cursor:pointer;transition:all .15s;margin-left:auto;display:flex;align-items:center;gap:4px}.tree-inline-add:hover{border-color:#22c55e66;color:#22c55e;background:#22c55e14}.tree-inline-add.rock-add{margin-left:0}.add-rock-row{padding:4px}.tree-rocks-summary{display:flex;align-items:center;padding:4px 4px 4px 28px}.rocks-info{display:flex;align-items:center;gap:6px;font-size:11px;color:#fff6;padding:6px 10px;background:#ffffff0a;border-radius:4px}.rocks-info svg{color:#22c55e}.rocks-info .revealed{color:#22c55e}.rock-icon{border-radius:50%!important;background:#ffffff0f;color:#ffffff80}.status-dot{width:6px;height:6px;border-radius:50%;background:#fff3;display:inline-block;margin-left:4px}.status-dot.active{background:#22c55e;box-shadow:0 0 6px #22c55e66}.tree-house{margin-bottom:4px}.tree-collection{position:relative}@media(max-width:768px){.tree-actions{opacity:1}.tree-name{font-size:14px}.tree-row{padding:10px 4px}.tree-icon{width:28px;height:28px}}.invitations-panel{background:#0f0f23f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:16px;overflow:hidden}.invitations-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08);color:#ffffffb3;font-size:13px;font-weight:600}.invitations-header svg{color:#06b6d4}.invitation-count{background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:auto}.invitations-loading{padding:20px;text-align:center;color:#fff6;font-size:13px}.invitations-list{max-height:300px;overflow-y:auto}.invitation-item{display:flex;flex-direction:column;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);border-left:3px solid #667eea;transition:background .2s}.invitation-item:last-child{border-bottom:none}.invitation-item:hover{background:#ffffff08}.invitation-content{display:flex;flex-direction:column;gap:6px}.invitation-from{display:flex;align-items:center;gap:8px}.inviter-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.inviter-avatar.placeholder{background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#ffffff80}.inviter-name{font-size:13px;font-weight:600;color:#fff}.invitation-details{display:flex;flex-wrap:wrap;align-items:center;gap:4px;font-size:13px;line-height:1.5}.invitation-action{color:#ffffff73}.invitation-item-name{font-weight:600;color:#fff}.invitation-type{color:#ffffff73}.invitation-type:before{content:"("}.invitation-type:after{content:")"}.invitation-role{color:#06b6d4;font-weight:500}.invitation-time{font-size:11px;color:#ffffff59}.invitation-actions{display:flex;gap:8px}.accept-btn,.decline-btn{flex:1;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.accept-btn{background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border:none}.accept-btn:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 12px #06b6d44d}.accept-btn:disabled{opacity:.5;cursor:not-allowed}.decline-btn{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.decline-btn:hover:not(:disabled){background:#ef44441a;border-color:#ef444480}.decline-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.invitations-header{padding:10px 14px;font-size:12px}.invitation-item{padding:12px 14px}.invitation-details{font-size:12px}.accept-btn,.decline-btn{padding:6px 10px;font-size:11px}}.help-section{margin-top:16px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.help-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;color:#ffffffa6;transition:all .2s}.help-toggle:hover{background:#ffffff14;border-color:#ffffff2e;color:#fff}.help-toggle span{flex:1;text-align:left}.help-toggle .chevron{color:#fff6;transition:transform .2s}.help-toggle .chevron.up{transform:rotate(180deg)}.help-content{margin-top:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;animation:slideDown .2s ease-out}.help-item{border-bottom:1px solid rgba(255,255,255,.06)}.help-item:last-of-type{border-bottom:none}.help-item-header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;background:transparent;border:none;cursor:pointer;transition:background .2s}.help-item-header:hover{background:#ffffff0d}.help-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.help-title{flex:1;text-align:left;font-size:13px;font-weight:600;color:#ffffffa6}.item-chevron{color:#fff6;transition:transform .2s}.item-chevron.up{transform:rotate(180deg)}.help-item-content{padding:0 14px 14px 44px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.help-item-content p{margin:0;font-size:12px;line-height:1.6;color:#fff6}.help-item.expanded .help-item-header{background:#ffffff0d}.help-item.expanded .help-title{color:#fff}.help-footer{padding:12px 14px;background:#ffffff08;border-top:1px solid rgba(255,255,255,.06)}.help-footer p{margin:0;font-size:11px;color:#ffffff4d;text-align:center}@media(max-width:768px){.help-toggle{padding:8px 10px;font-size:12px}.help-item-header{padding:10px 12px}.help-title{font-size:12px}.help-item-content{padding:0 12px 12px 38px}.help-item-content p{font-size:11px}}.map-legend{position:fixed;top:0;right:0;width:320px;height:100vh;background:#0a0a1aeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-left:1px solid rgba(255,255,255,.08);box-shadow:-2px 0 24px #0006;display:flex;flex-direction:column;z-index:1000;transition:width .05s linear}.map-legend[style*=width]{transition:none}.map-legend.collapsed{width:60px!important;transition:width .25s ease}.map-legend.collapsed .legend-header{padding:12px;justify-content:center}.map-legend.collapsed .legend-brand{justify-content:center}.map-legend.hidden{height:0!important;min-height:0!important;padding:0!important;overflow:hidden!important;border:none!important;box-shadow:none!important}.mobile-reveal-btn{display:none;position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-weight:600;box-shadow:0 10px 25px #22c55e4d;z-index:1001;gap:8px;align-items:center;animation:reveal-pulse .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes reveal-pulse{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.resize-handle{position:absolute;left:0;top:0;bottom:0;width:16px;cursor:ew-resize;z-index:101;display:flex;align-items:center;justify-content:center;transform:translate(-50%)}.resize-line{width:4px;height:48px;background-color:#ffffff26;border-radius:2px;opacity:0;transition:opacity .2s}.resize-handle:hover .resize-line{opacity:1}.legend-toggle{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:20px;height:64px;background:#0a0a1aeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff6;box-shadow:-2px 0 8px #0000004d;z-index:99;transition:all .2s ease}.legend-toggle:hover{background:#ffffff14;color:#ffffffb3;width:24px;left:-24px}.legend-toggle svg{width:12px;height:12px}.legend-header{padding:14px 16px;background:#0a0a1af2;border-bottom:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-shrink:0}.legend-brand{display:flex;align-items:center;gap:10px;min-width:0}.legend-logo{width:40px;height:40px;border-radius:8px;flex-shrink:0}.brand-text{display:flex;flex-direction:column;min-width:0}.legend-header h3.brand-title{margin:0;font-family:Fredoka,sans-serif;font-size:20px;font-weight:700;background:linear-gradient(135deg,#22c55e,#06b6d4,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-slogan{font-size:11px;font-weight:500;color:#fff6;letter-spacing:.5px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.mobile-close-btn,.mobile-expand-btn{display:none;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#ffffff80;padding:6px;cursor:pointer;border-radius:8px;transition:all .2s}.mobile-close-btn:hover{background:#ef444426;border-color:#ef44444d;color:#ef4444}.notification-bell{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;color:#ffffff80;transition:all .2s ease}.notification-bell:hover{background:#ffffff14;color:#ffffffb3;border-color:#ffffff1f}.notification-bell.active{background:#22c55e1f;color:#22c55e;border-color:#22c55e4d}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;font-size:10px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(10,10,26,.92);animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.guest-notice{text-align:center;padding:24px 16px;background:#06b6d414;border-radius:12px;border:1px solid rgba(6,182,212,.15)}.guest-icon{width:56px;height:56px;margin:0 auto 12px;background:#06b6d41f;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#06b6d4;box-shadow:0 2px 12px #06b6d426}.guest-title{margin:0 0 8px;font-size:16px;font-weight:700;color:#fff}.guest-text{margin:0;font-size:13px;color:#ffffff80;line-height:1.5}.legend-stats{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:600;color:#ffffffa6;flex-shrink:0}.legend-stats svg{color:#22c55e}.legend-stats .hidden-count-hint{display:flex;align-items:center;gap:4px;margin-left:auto;color:#8b5cf6;font-weight:500;font-size:12px}.legend-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.legend-content::-webkit-scrollbar{width:6px}.legend-content::-webkit-scrollbar-track{background:#ffffff05}.legend-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.legend-content::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.shared-houses-section{border-top:1px solid rgba(255,255,255,.06);padding-top:16px;margin-top:8px}.shared-header{display:flex;align-items:center;gap:8px;padding:8px 4px;cursor:pointer;border-radius:6px;transition:background-color .15s}.shared-header:hover{background-color:#ffffff0f}.shared-expand{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#fff6;transition:transform .2s,color .15s;flex-shrink:0}.shared-expand:hover{color:#ffffffb3}.shared-expand.expanded{transform:rotate(90deg)}.shared-icon{color:#8b5cf6;flex-shrink:0}.shared-title{font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.shared-count{font-size:11px;font-weight:600;color:#fff;background:linear-gradient(135deg,#22c55e,#06b6d4);padding:2px 8px;border-radius:10px;margin-left:auto}.shared-list{margin-top:8px;display:flex;flex-direction:column;gap:4px}.shared-house-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;transition:background-color .15s;margin-left:20px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.shared-house-item:hover{background-color:#ffffff14}.shared-house-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shared-house-icon img{width:18px;height:18px;object-fit:contain}.shared-house-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.shared-house-name{font-size:13px;font-weight:600;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shared-house-meta{font-size:11px;color:#fff6}@media(max-width:768px){.map-legend{width:100%!important;height:50vh;top:auto;bottom:0;border-radius:16px 16px 0 0;border-left:none;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -2px 24px #0006;transition:height .3s ease}.map-legend.expanded{height:100vh;border-radius:0}.map-legend.collapsed{width:100%!important;height:auto;min-height:60px}.mobile-reveal-btn{display:flex}.legend-toggle,.resize-handle{display:none}.mobile-close-btn,.mobile-expand-btn{display:flex;align-items:center;justify-content:center}.legend-header{border-radius:16px 16px 0 0;cursor:pointer;position:relative;padding-top:20px}.legend-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#ffffff26;border-radius:2px}.map-legend.expanded .legend-header{border-radius:0}.map-legend.dragging{transition:none}}.header-actions-collapsed{display:flex;align-items:center;gap:8px}.invitations-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:200;animation:overlay-fade-in .2s ease}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.invitations-modal{position:relative;width:100%;max-width:480px;min-width:320px;max-height:calc(100vh - 160px);background:#0a0a1af2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 20px 50px #00000080;overflow:hidden;animation:modal-slide-in .25s ease}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.invitations-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#ffffff80;z-index:10;transition:all .15s ease}.invitations-modal-close:hover{background:#ffffff14;color:#fffc}.invitations-modal .invitations-panel{margin-bottom:0;box-shadow:none;border-radius:0}.invitations-modal .invitations-list{max-height:calc(100vh - 280px)}@media(max-width:480px){.legend-header .user-name{display:none}.invitations-modal-overlay{padding:60px 20px 20px;align-items:flex-start}.invitations-modal{max-width:100%;max-height:calc(100vh - 100px)}.notification-bell{width:32px;height:32px}.notification-badge{min-width:16px;height:16px;font-size:9px;top:-3px;right:-3px}}.map-search{position:relative;width:100%;max-width:400px}.search-input-container{position:relative;display:flex;align-items:center;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 4px 24px #0000004d;transition:all .2s ease}.search-input-container:focus-within{background:#ffffff14;border-color:#fff3;box-shadow:0 8px 32px #0006;transform:translateY(-1px)}.search-icon{position:absolute;left:14px;color:#fff6;pointer-events:none}.search-input{width:100%;padding:14px 40px 14px 44px;border:none;border-radius:16px;font-size:14px;color:#fff;outline:none;background:transparent}.search-input::placeholder{color:#ffffff4d}.search-loading{color:#fff6}.clear-button{position:absolute;right:10px;width:28px;height:28px;padding:0;border:none;background:none;color:#fff6;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.clear-button:hover{background-color:#ffffff14;color:#fff}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#0a0a1af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #00000080;max-height:300px;overflow-y:auto;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid rgba(255,255,255,.06)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#ffffff14}.suggestion-icon{color:#fff6;flex-shrink:0;margin-top:2px}.suggestion-text{flex:1;min-width:0}.suggestion-main{font-size:14px;font-weight:600;color:#fff;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-secondary{font-size:12px;color:#fff6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.map-search{max-width:100%}.search-input{font-size:16px}.search-suggestions{max-height:200px}}.search-suggestions::-webkit-scrollbar{width:8px}.search-suggestions::-webkit-scrollbar-track{background:#ffffff08;border-radius:4px}.search-suggestions::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.search-suggestions::-webkit-scrollbar-thumb:hover{background:#ffffff40}.house-creator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.house-creator-modal{background:#0f0f23f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 8px 32px #0006;max-width:560px;width:100%;max-height:92vh;overflow-y:auto;animation:slideUp .2s ease-out}.house-creator-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.house-creator-header h2{margin:0;font-size:20px;font-weight:800;color:#fff}.close-button{background:none;border:none;cursor:pointer;padding:4px;color:#fff6;transition:color .15s;display:flex;align-items:center;justify-content:center}.house-creator-form{padding:24px}.color-preview-container{margin-bottom:16px}.color-preview{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:12px;color:#fff}.preview-house-icon{width:40px;height:40px;background:#fff3;border-radius:10px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-house-icon img{width:28px;height:28px;filter:brightness(0) invert(1)}.preview-house-icon img.custom-preview{width:32px;height:32px;border-radius:6px;filter:none;object-fit:cover}.preview-name{font-size:16px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}.color-tabs{display:flex;gap:8px;margin-bottom:12px}.color-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#ffffff0f;border:2px solid rgba(255,255,255,.12);border-radius:8px;font-size:13px;font-weight:600;color:#ffffff80;cursor:pointer;transition:all .15s}.color-tab:hover{border-color:#fff3}.color-tab.active{background:#ffffff1a;border-color:#ffffff4d;color:#fff}.color-tab-swatch{width:16px;height:16px;border-radius:4px;border:2px solid rgba(255,255,255,.3);box-shadow:0 1px 2px #0003}.color-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;margin-bottom:12px}.color-swatch{aspect-ratio:1;border-radius:6px;border:2px solid rgba(255,255,255,.1);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 -2px 4px #0003}.color-swatch:hover{transform:scale(1.1);z-index:1;border-color:#ffffff4d}.color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px #0f0f23f2,0 0 0 4px #fff,0 0 12px #ffffff4d;transform:scale(1.05)}.custom-color-row{display:flex;align-items:center;gap:10px}.custom-color-row span{font-size:13px;color:#ffffff80}.custom-color-row input[type=color]{width:36px;height:36px;padding:0;border:2px solid rgba(255,255,255,.12);border-radius:8px;cursor:pointer;background:transparent}.custom-color-row input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.custom-color-row input[type=color]::-webkit-color-swatch{border-radius:4px;border:none}.logo-tabs{display:flex;gap:8px;margin-bottom:12px}.logo-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;background:#ffffff0f;border:2px solid rgba(255,255,255,.12);border-radius:8px;font-size:13px;font-weight:600;color:#ffffff80;cursor:pointer;transition:all .15s}.logo-tab:hover{border-color:#fff3}.logo-tab.active{background:#ffffff1a;border-color:#ffffff4d;color:#fff}.logo-tab svg{flex-shrink:0}.logo-selector{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;max-height:260px;overflow-y:auto;padding:4px}.logo-option{position:relative;aspect-ratio:1;padding:8px;background:#ffffff0f;border:3px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.logo-option:hover{background:#ffffff1a;transform:scale(1.05)}.logo-option.selected{background:#06b6d41a;border:2px solid #06b6d4;box-shadow:0 0 12px #06b6d44d}.logo-option img{width:100%;height:100%;object-fit:contain}.logo-check{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000004d}.logo-upload-area{margin-top:8px}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;background:#ffffff0a;border:2px dashed rgba(255,255,255,.15);border-radius:12px;cursor:pointer;transition:all .15s;text-align:center;color:#ffffff80}.upload-dropzone:hover{border-color:#ffffff4d;background:#ffffff0f}.upload-dropzone svg{margin-bottom:8px;color:#ffffff4d}.upload-text{font-size:14px;font-weight:600;color:#ffffffa6;margin-bottom:4px}.upload-hint{font-size:12px;color:#ffffff59}.hidden-input{display:none}.uploaded-logo-preview{position:relative;display:flex;align-items:center;justify-content:center;padding:20px;background:#ffffff0f;border:2px solid rgba(255,255,255,.12);border-radius:12px}.uploaded-logo-preview img{max-width:120px;max-height:120px;object-fit:contain;border-radius:8px}.remove-logo-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s}.remove-logo-btn:hover{background:#dc2626}@media(max-width:768px){.house-creator-overlay{padding:0;align-items:flex-end}.house-creator-modal{max-width:100%;width:100%;margin:0;border-radius:20px 20px 0 0;max-height:90vh}.color-grid{grid-template-columns:repeat(6,1fr)}.logo-selector{grid-template-columns:repeat(5,1fr);gap:6px;max-height:200px}.logo-option{padding:6px;border-radius:8px}.logo-check{width:16px;height:16px;top:-4px;right:-4px}.logo-check svg{width:10px;height:10px}}@media(max-width:480px){.color-grid{grid-template-columns:repeat(5,1fr)}.color-tabs{flex-direction:column}.color-tab{padding:8px 12px}}.collection-creator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.collection-creator-modal{background:#0f0f23f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 8px 32px #0006;max-width:480px;min-width:320px;width:100%;animation:slideUp .2s ease-out}.collection-creator-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.collection-creator-header h2{margin:0;font-size:18px;font-weight:800;color:#fff}.header-subtitle{margin:4px 0 0;font-size:13px;color:#ffffff73}.close-button{background:none;border:none;cursor:pointer;padding:4px;color:#fff6;transition:color .15s;display:flex}.close-button:hover{color:#fff}.collection-creator-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:13px;font-weight:600;color:#ffffffa6}.form-group input[type=text],.form-group textarea{width:100%;padding:12px 16px;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;background:#ffffff0f;color:#fff;box-sizing:border-box}.form-group input[type=text]::placeholder,.form-group textarea::placeholder{color:#ffffff4d}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d426}.form-group textarea{resize:vertical;min-height:80px}.form-error{padding:12px;background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:13px;margin-bottom:16px}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.toggle-text{display:flex;flex-direction:column;gap:2px}.toggle-title{font-size:13px;font-weight:600;color:#ffffffa6}.toggle-hint{font-size:12px;color:#fff6;font-weight:400}.toggle-switch{position:relative;width:44px;height:24px;background:#ffffff26;border:none;border-radius:12px;cursor:pointer;transition:background .2s}.toggle-switch.active{background:linear-gradient(135deg,#22c55e,#06b6d4)}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d;transition:transform .2s}.toggle-switch.active .toggle-knob{transform:translate(20px)}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions button{flex:1;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s}.btn-cancel{background:transparent;border:1px solid rgba(255,255,255,.2);color:#ffffffa6}.btn-cancel:hover:not(:disabled){border-color:#ffffff59;color:#fff}.btn-create{background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border:none;box-shadow:0 2px 8px #06b6d44d}.btn-create:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #06b6d466}.btn-cancel:disabled,.btn-create:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.collection-creator-modal{margin:0 12px}.collection-creator-form{padding:20px}}.rock-creator-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.rock-creator-modal{background:#0f0f23f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080}.rock-creator-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.rock-creator-header h2{margin:0;font-size:20px;font-weight:800;color:#fff}.rock-creator-header .header-subtitle{margin:4px 0 0;font-size:13px;color:#ffffff80}.rock-creator-header .close-button{background:none;border:none;padding:4px;cursor:pointer;color:#fff6;border-radius:6px;transition:all .15s}.rock-creator-header .close-button:hover{background:#ffffff14;color:#fff}.rock-creator-form{padding:24px}.rock-creator-form .form-group{margin-bottom:20px}.rock-creator-form label{display:block;font-size:14px;font-weight:600;color:#ffffffa6;margin-bottom:8px}.rock-creator-form input,.rock-creator-form textarea{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:15px;color:#fff;background:#ffffff0f;transition:all .15s;box-sizing:border-box}.rock-creator-form input:focus,.rock-creator-form textarea:focus{outline:none;border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d426}.rock-creator-form input::placeholder,.rock-creator-form textarea::placeholder{color:#ffffff4d}.rock-creator-form .input-hint{margin:6px 0 0;font-size:12px;color:#fff6}.rock-creator-form .form-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#f87171;padding:12px 14px;border-radius:10px;font-size:14px;margin-bottom:20px}.tier-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.tier-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#ffffff0a;border:2px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .15s}.tier-option:hover:not(.disabled){background:#ffffff14;border-color:#fff3}.tier-option.selected{background:color-mix(in srgb,var(--tier-color) 15%,transparent);border-color:var(--tier-color);box-shadow:0 0 12px color-mix(in srgb,var(--tier-color) 25%,transparent)}.tier-option.disabled{opacity:.4;cursor:not-allowed}.tier-dot{width:12px;height:12px;border-radius:50%;background:var(--tier-color)}.tier-name{font-size:11px;font-weight:600;color:#ffffffb3;text-transform:capitalize}.tier-locked{font-size:9px;color:#ffffff59;font-weight:500}.tier-hint{margin:8px 0 0;font-size:12px;color:#fff6}.rock-creator-form .form-actions{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}.rock-creator-form .btn-cancel{flex:1;padding:12px 20px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:10px;font-size:15px;font-weight:600;color:#ffffffb3;cursor:pointer;transition:all .15s}.rock-creator-form .btn-cancel:hover{background:#ffffff0f;border-color:#ffffff4d;color:#fff}.rock-creator-form .btn-create{flex:1;padding:12px 20px;background:linear-gradient(135deg,#22c55e,#06b6d4);border:none;border-radius:10px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s}.rock-creator-form .btn-create:hover{filter:brightness(1.1);box-shadow:0 4px 15px #06b6d44d}.rock-creator-form .btn-create:disabled,.rock-creator-form .btn-cancel:disabled{opacity:.5;cursor:not-allowed}.rock-created-success{max-width:400px}.qr-success-content{padding:24px;text-align:center}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;margin-bottom:24px}.qr-code-image{width:200px;height:200px;border-radius:8px;box-shadow:0 2px 8px #0000004d;background:#fff;padding:8px}.rock-code{font-family:monospace;font-size:14px;font-weight:600;color:#fffc;background:#ffffff0f;padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.qr-instructions{text-align:left;margin-bottom:24px}.qr-instructions h3{font-size:14px;font-weight:600;color:#ffffffa6;margin:0 0 16px}.instruction-step{display:flex;gap:12px;margin-bottom:12px}.instruction-step .step-number{width:24px;height:24px;background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.instruction-step strong{display:block;font-size:14px;color:#fff;margin-bottom:2px}.instruction-step p{font-size:13px;color:#ffffff80;margin:0}.qr-actions{display:flex;gap:12px;margin-bottom:16px}.btn-download,.btn-manual-place{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.btn-download{background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;border:none}.btn-download:hover{filter:brightness(1.1);box-shadow:0 4px 15px #06b6d44d}.btn-manual-place{background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.2)}.btn-manual-place:hover{background:#ffffff0f;border-color:#ffffff4d;color:#fff}.scan-url-hint{display:flex;flex-direction:column;gap:6px;padding:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;font-size:12px}.scan-url-hint span{color:#ffffff80}.scan-url-hint code{font-family:monospace;font-size:11px;color:#ffffffb3;background:#ffffff0f;padding:6px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.1);word-break:break-all}@media(max-width:480px){.rock-creator-modal{max-height:100vh;border-radius:20px 20px 0 0;margin-top:auto}.tier-selector{grid-template-columns:repeat(2,1fr)}.qr-actions{flex-direction:column}}.rarity-legend{position:absolute;bottom:20px;left:20px;z-index:10;pointer-events:auto}.rarity-legend-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 4px 24px #0000004d;cursor:pointer;font-size:13px;font-weight:600;color:#fff;transition:all .2s ease}.rarity-legend-toggle:hover{background:#ffffff14;border-color:#fff3;box-shadow:0 6px 28px #0006;transform:translateY(-1px)}.legend-icon{color:#fbbf24;display:flex;align-items:center}.legend-title{flex:1}.filter-badge{background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.legend-arrow{display:flex;align-items:center;color:#fff6;transition:transform .2s ease}.legend-arrow.up{transform:rotate(180deg)}.legend-arrow:hover{color:#ffffffb3}.rarity-legend-content{position:absolute;bottom:50px;left:0;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 40px #0006;padding:16px;min-width:240px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.legend-actions{display:flex;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08)}.action-btn{flex:1;padding:6px 12px;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff0f;color:#ffffff80;cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff3;color:#fffc}.action-btn:disabled{opacity:.4;cursor:not-allowed}.action-btn.active{background:#22c55e33;border-color:#22c55e66;color:#22c55e}.rarity-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;transition:background-color .2s;cursor:pointer}.rarity-item:hover{background-color:#ffffff0f}.rarity-item.inactive{opacity:.7}.rarity-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.rarity-item.active .rarity-checkbox{background:#22c55e;border-color:#22c55e}.rarity-color{width:20px;height:20px;border-radius:50%;flex-shrink:0;transition:all .2s}.rarity-info{display:flex;flex-direction:column;gap:2px}.rarity-name{font-size:13px;font-weight:600;text-transform:capitalize;color:#fff;transition:opacity .2s}.rarity-points{font-size:11px;color:#fff6;transition:opacity .2s}.map-layers-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.map-layers-header{font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 8px}.map-layer-toggle{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:10px;cursor:pointer;transition:background-color .2s}.map-layer-toggle:hover{background-color:#ffffff0f}.map-layer-toggle.active{background-color:#22c55e14}.layer-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a78bfa,#ec4899);border-radius:8px;color:#fff;flex-shrink:0}.layer-info{flex:1;display:flex;flex-direction:column;gap:2px}.layer-name{font-size:13px;font-weight:600;color:#fff}.layer-desc{font-size:11px;color:#fff6}.layer-switch{width:40px;height:22px;border-radius:11px;background:#ffffff26;position:relative;transition:background .2s;flex-shrink:0}.layer-switch.on{background:linear-gradient(135deg,#22c55e,#06b6d4)}.switch-thumb{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.layer-switch.on .switch-thumb{transform:translate(18px)}.map-symbols-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.map-symbols-header{font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 8px}.map-symbol-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px}.symbol-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cluster-icon{width:24px;height:24px;border-radius:50%;background-color:#a78bfa;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px}.symbol-text{display:flex;flex-direction:column}.symbol-label{font-size:12px;color:#ffffffa6}.heatmap-icon{background:linear-gradient(135deg,#00ffc84d,#9664ff80,#c850c899);border-radius:50%}.heatmap-gradient{width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,rgba(200,80,200,.6) 0%,rgba(100,150,255,.3) 50%,transparent 70%)}@media(max-width:768px){.rarity-legend{bottom:12px;left:12px}.rarity-legend-toggle{padding:8px 12px;font-size:12px}.rarity-legend-content{padding:8px;bottom:45px;min-width:200px}.rarity-item{padding:6px}.rarity-color{width:16px;height:16px}.rarity-name{font-size:12px}.rarity-points{font-size:10px}}.gm-style-iw-c{background:#0f0f23f2!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:14px!important;padding:0!important}.gm-style-iw-d{overflow:auto!important}.gm-style-iw-tc:after{display:none!important}.gm-style-iw button[aria-label=Close]{color:#ffffff80!important}.heatmap-info{padding:8px 12px;text-align:center;min-width:120px}.heatmap-info-count{font-size:28px;font-weight:700;color:#06b6d4;line-height:1}.heatmap-info-label{font-size:13px;color:#ffffffa6;margin-top:4px}.heatmap-info-hint{font-size:11px;color:#fff6;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.heatmap-areas-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.heatmap-areas-header{font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 8px;display:flex;align-items:center;gap:6px}.heatmap-areas-header svg{width:14px;height:14px;color:#a855f7}.heatmap-areas-list{max-height:150px;overflow-y:auto}.heatmap-area-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background-color .2s}.heatmap-area-item:hover{background-color:#ffffff0f}.heatmap-area-dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#06b6d4);flex-shrink:0}.heatmap-area-info{flex:1;min-width:0}.heatmap-area-name{font-size:13px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.heatmap-area-count{font-size:11px;color:#fff6}.heatmap-no-areas{padding:12px 8px;text-align:center;color:#ffffff4d;font-size:12px}.heatmap-zoom-warning{position:absolute;top:100px;left:50%;transform:translate(-50%);background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);padding:8px 16px;border-radius:20px;box-shadow:0 4px 24px #0000004d;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:#ffffffa6;z-index:10;pointer-events:none;animation:fadeIn .3s ease-out}.warning-icon{font-size:16px}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.rock-map-view{position:relative;width:100%;height:100vh;overflow:hidden;background:#0a0a1a}.rock-map-view>div:not(.map-controls):not(.rock-count-badge):not(.map-legend){width:100%!important;height:100%!important}.map-controls{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10;padding:20px;display:flex;flex-direction:column}.map-controls>*{pointer-events:auto}.map-controls-top{display:flex;justify-content:center;margin-bottom:auto;pointer-events:none}.map-controls-top>*{pointer-events:auto}.map-controls-bottom-left{position:absolute;bottom:20px;left:20px;pointer-events:none}.map-controls-bottom-left>*{pointer-events:auto}.map-controls-bottom-right{position:absolute;bottom:20px;right:20px}.user-location-marker{position:relative;width:20px;height:20px}.user-location-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#06b6d4;border:3px solid rgba(255,255,255,.9);border-radius:50%;box-shadow:0 2px 8px #06b6d480,0 0 16px #06b6d44d;z-index:2}.user-location-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#06b6d44d;border-radius:50%;animation:pulse 2s infinite;z-index:1}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}@media(max-width:768px){.rock-map-view{width:100%;height:100vh}.map-controls{padding:12px}.map-controls-bottom-left{bottom:12px;left:12px}.rock-count-badge{top:70px;padding:8px 16px;font-size:13px}.map-controls-top{width:100%;padding:0 12px}}@media(max-width:480px){.rock-count-badge{font-size:12px;padding:6px 12px}.rock-count-badge svg{width:16px;height:16px}}@media(max-height:500px)and (orientation:landscape){.map-controls{padding:8px}.rock-count-badge{top:60px}.map-controls-bottom-left,.map-controls-bottom-right{bottom:8px}}.cluster-marker{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;color:#fff;font-weight:700;font-size:16px;border:3px solid rgba(255,255,255,.2);box-shadow:0 2px 12px #00000080,0 0 20px #22c55e33;cursor:pointer;transition:transform .2s ease}.cluster-marker:hover{transform:scale(1.1)}.rock-map-view.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#22c55e;border-radius:50%;animation:spin 1s linear infinite;z-index:1000}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.placement-mode-overlay{position:fixed;top:0;left:320px;right:0;z-index:1000;pointer-events:none}@media(max-width:768px){.placement-mode-overlay{left:0;bottom:auto}}.placement-mode-banner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:16px;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-top:none;color:#fff;padding:16px 24px;margin:16px;border-radius:16px;box-shadow:0 8px 32px #0006,0 0 30px #22c55e26;pointer-events:auto;overflow:hidden}.placement-mode-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(135deg,#22c55e,#06b6d4);border-radius:16px 16px 0 0}.placement-info{display:flex;align-items:center;gap:12px}.placement-icon{width:40px;height:40px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.placement-icon svg{width:22px;height:22px;color:#22c55e}.placement-info strong{display:block;font-size:15px;font-weight:600;margin-bottom:2px;color:#fff}.placement-info p{margin:0;font-size:13px;color:#ffffffa6}.cancel-placement-btn{background:transparent;border:2px solid rgba(255,255,255,.2);color:#fff;padding:10px 20px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.cancel-placement-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d}.cancel-placement-btn:disabled{opacity:.7;cursor:wait}.map-placement-mode,.map-placement-mode *{cursor:crosshair!important}@media(max-width:600px){.placement-mode-banner{flex-direction:column;text-align:center;margin:12px;padding:14px 18px}.placement-info{flex-direction:column}.cancel-placement-btn{width:100%}}.rock-3d-container{position:relative;width:100%;touch-action:none;cursor:grab;border-radius:12px;overflow:hidden;background:radial-gradient(ellipse at center,#1e1e28cc,#0a0a14f2)}.rock-3d-container:active{cursor:grabbing}.rock-3d-container canvas{border-radius:12px}.rock-3d-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-size:11px;color:#ffffff80;pointer-events:none;opacity:0;transition:opacity .3s ease;white-space:nowrap}.rock-3d-container:hover .rock-3d-hint{opacity:1}.rock-3d-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#1a1a2e;border-radius:12px}.rock-3d-fallback img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px}.rock-3d-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:1}.rock-3d-loading img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px;filter:brightness(.7)}.house-page{min-height:100vh;background-color:#f9fafb}.house-page-loading,.house-page-error{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#6b7280}.house-hero{height:300px;position:relative;display:flex;align-items:flex-end;padding:40px;color:#fff}.house-hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%)}.house-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:16px;max-width:1200px;width:100%;margin:0 auto}.house-icon-large{width:80px;height:80px;background:#fff;border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 25px #0003;overflow:hidden}.house-icon-large img{width:100%;height:100%;object-fit:cover}.house-initial{font-size:40px;font-weight:800;color:#374151}.house-hero h1{font-size:3rem;margin:0;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.3)}.house-stats-badges{display:flex;gap:10px}.badge{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px 12px;border-radius:99px;font-size:.9rem;font-weight:600;border:1px solid rgba(255,255,255,.3)}.house-container{max-width:1200px;margin:0 auto;padding:40px 20px}.house-lore{background:#fff;padding:30px;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:40px}.house-lore h2{font-size:1.5rem;color:#111827;margin-top:0;margin-bottom:16px;border-bottom:2px solid #f3f4f6;padding-bottom:10px}.house-lore p{color:#4b5563;line-height:1.8;font-size:1.1rem}.house-collections h2{font-size:1.5rem;color:#111827;margin-bottom:24px}.collections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.collection-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;transition:transform .2s,box-shadow .2s;border:1px solid #e5e7eb}.collection-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a}.collection-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;border-left:4px solid transparent;padding-left:12px}.collection-header h3{margin:0;font-size:1.25rem;color:#1f2937}.collection-progress{font-size:.8rem;color:#6b7280;font-weight:500;background:#f3f4f6;padding:4px 8px;border-radius:6px}.collection-card p{color:#6b7280;font-size:.95rem;margin-bottom:20px;line-height:1.5}.progress-bar-bg{width:100%;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease-out}.empty-state{color:#9ca3af;font-style:italic}.back-btn{display:inline-block;margin-top:40px;color:#4b5563;text-decoration:none;font-weight:500;padding:10px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s}.back-btn:hover{background:#f9fafb;color:#111827;border-color:#d1d5db}@media(max-width:768px){.house-hero{height:250px;padding:20px}.house-hero h1{font-size:2rem}.collections-grid{grid-template-columns:1fr}}.shared-with-me-page{min-height:100vh;background:#f8fafc}.shared-header{background:linear-gradient(135deg,#3b82f6,#2563eb);padding:16px 20px 32px;color:#fff}.shared-header .back-link{display:inline-flex;align-items:center;gap:8px;color:#ffffffe6;text-decoration:none;font-weight:500;font-size:14px;margin-bottom:16px;transition:color .2s}.shared-header .back-link:hover{color:#fff}.header-content h1{font-size:28px;font-weight:700;margin:0 0 8px}.header-subtitle{font-size:14px;opacity:.9;margin:0}.tabs-container{background:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #00000014}.tabs{max-width:800px;margin:0 auto;display:flex;padding:0 16px}.tab{display:flex;align-items:center;gap:8px;padding:14px 20px;border:none;background:transparent;color:#6b7280;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;flex:1;justify-content:center}.tab:hover{color:#1f2937;background:#3b82f60d}.tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-icon{display:flex;align-items:center;justify-content:center}.tab-icon svg{width:18px;height:18px}.tab-count{background:#e5e7eb;color:#4b5563;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px}.tab.active .tab-count{background:#3b82f6;color:#fff}.shared-content{max-width:800px;margin:0 auto;padding:24px 20px}.loading-container{display:flex;flex-direction:column;align-items:center;padding:60px 20px}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-container p{color:#64748b;font-size:14px;margin:0}.error-container{display:flex;flex-direction:column;align-items:center;padding:60px 20px;text-align:center}.error-icon{color:#ef4444;margin-bottom:16px}.error-container p{color:#64748b;font-size:15px;margin:0 0 20px}.retry-button{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.retry-button:hover{background:#2563eb}.empty-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px;text-align:center}.empty-icon{color:#94a3b8;margin-bottom:20px}.empty-state h2{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 8px}.empty-state p{color:#64748b;font-size:14px;margin:0 0 24px;max-width:300px}.explore-button{display:inline-block;background:#3b82f6;color:#fff;text-decoration:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;transition:background .2s}.explore-button:hover{background:#2563eb}.tab-empty{padding:40px 20px;text-align:center;color:#64748b;font-size:14px}.items-list{display:flex;flex-direction:column;gap:12px}.shared-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border-left:4px solid #3b82f6;cursor:pointer;transition:all .2s}.shared-item:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.item-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.item-icon img{width:100%;height:100%;object-fit:cover}.item-icon.rock-icon{border-radius:50%}.rock-emoji{font-size:24px}.item-info{flex:1;min-width:0}.item-name{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.house-badge{display:inline-block;font-size:12px;font-weight:600;margin-bottom:4px}.item-description{font-size:13px;color:#64748b;margin:0 0 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rocks-count{font-size:12px;color:#64748b}.tier-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase}.tier-badge.tier-common{background:#e5e7eb;color:#6b7280}.tier-badge.tier-uncommon{background:#d1fae5;color:#059669}.tier-badge.tier-rare{background:#dbeafe;color:#2563eb}.tier-badge.tier-epic{background:#ede9fe;color:#7c3aed}.tier-badge.tier-legendary{background:#fef3c7;color:#d97706}.tier-badge.tier-mythic{background:#fee2e2;color:#dc2626}.points-badge{font-size:12px;color:#64748b;font-weight:500}.item-share-info{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.shared-by{display:flex;align-items:center;gap:6px}.sharer-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.sharer-avatar.placeholder{background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#6b7280}.sharer-name{font-size:12px;color:#64748b;max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;color:#fff;text-transform:uppercase}.shared-time{font-size:11px;color:#9ca3af}@media(max-width:640px){.shared-header{padding:12px 16px 24px}.header-content h1{font-size:24px}.tabs{padding:0 8px}.tab{padding:12px 8px;font-size:13px;gap:6px}.tab-label{display:none}.tab.active .tab-label{display:inline}.shared-content{padding:16px}.shared-item{flex-wrap:wrap;padding:14px}.item-icon{width:40px;height:40px}.item-info{flex:1 1 calc(100% - 56px)}.item-share-info{width:100%;flex-direction:row;justify-content:space-between;align-items:center;padding-top:12px;margin-top:4px;border-top:1px solid #f1f5f9}.item-name{font-size:15px}}@media(prefers-color-scheme:dark){.shared-with-me-page{background:#111827}.shared-header{background:linear-gradient(135deg,#1e40af,#1d4ed8)}.tabs-container{background:#1f2937}.tab{color:#9ca3af}.tab:hover{color:#f3f4f6;background:#3b82f61a}.tab.active{color:#60a5fa;border-bottom-color:#60a5fa}.tab-count{background:#374151;color:#d1d5db}.tab.active .tab-count{background:#3b82f6;color:#fff}.shared-item{background:#1f2937;box-shadow:0 2px 8px #0003}.shared-item:hover{box-shadow:0 4px 16px #0000004d}.item-name{color:#f3f4f6}.item-description,.rocks-count,.points-badge,.sharer-name{color:#9ca3af}.sharer-avatar.placeholder{background:#374151;color:#9ca3af}.shared-time{color:#6b7280}.loading-container p,.error-container p,.tab-empty,.empty-state p{color:#9ca3af}.empty-state h2{color:#f3f4f6}.empty-icon{color:#6b7280}.tier-badge.tier-common{background:#374151;color:#9ca3af}.tier-badge.tier-uncommon{background:#064e3b;color:#34d399}.tier-badge.tier-rare{background:#1e3a8a;color:#60a5fa}.tier-badge.tier-epic{background:#4c1d95;color:#a78bfa}.tier-badge.tier-legendary{background:#78350f;color:#fbbf24}.tier-badge.tier-mythic{background:#7f1d1d;color:#f87171}}.scan-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px}.scan-loading{text-align:center;color:#fff}.loading-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.scan-loading p{font-size:18px;font-weight:500}.scan-error,.scan-success{background:#fff;border-radius:20px;padding:40px;text-align:center;max-width:400px;width:100%;box-shadow:0 25px 50px #00000040}.error-icon{width:64px;height:64px;background:#fee2e2;color:#dc2626;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 20px}.success-icon{width:64px;height:64px;background:#dcfce7;color:#16a34a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.success-icon svg{width:32px;height:32px}.scan-error h2,.scan-success h2{font-size:24px;font-weight:700;color:#111827;margin:0 0 12px}.scan-error p,.scan-success p{color:#6b7280;margin:0 0 24px}.rock-name{font-size:20px;font-weight:600;color:#111827!important;margin-bottom:12px!important}.points-awarded{display:flex;flex-direction:column;align-items:center;margin:24px 0;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px}.points-value{font-size:36px;font-weight:700;color:#b45309}.points-label{font-size:14px;color:#92400e;text-transform:uppercase;letter-spacing:1px}.scan-content{background:#fff;border-radius:20px;padding:32px;max-width:420px;width:100%;box-shadow:0 25px 50px #00000040}.rock-header{text-align:center;margin-bottom:24px}.rock-photo{width:120px;height:120px;border-radius:16px;object-fit:cover;margin-bottom:16px;box-shadow:0 4px 12px #00000026}.rock-header h1{font-size:24px;font-weight:700;color:#111827;margin:0 0 12px}.tier-badge{display:inline-block;padding:4px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.house-name{font-size:14px;font-weight:500;margin:12px 0 0}.inline-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:20px}.action-area{margin-bottom:24px}.place-flow,.claim-flow{text-align:center}.place-flow h2,.claim-flow h2{font-size:20px;font-weight:700;color:#111827;margin:0 0 12px}.place-flow p,.claim-flow p{color:#6b7280;font-size:15px;margin:0 0 20px;line-height:1.5}.find-count{font-size:13px;color:#9ca3af}.btn-place,.btn-claim{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-place{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-place:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.btn-claim{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-claim:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #22c55e66}.btn-place:disabled,.btn-claim:disabled{opacity:.7;cursor:wait}.btn-place svg,.btn-claim svg{width:20px;height:20px}.already-placed,.already-found{text-align:center}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:30px;font-size:14px;font-weight:600;margin-bottom:16px}.status-badge.success{background:#dcfce7;color:#16a34a}.status-badge.info{background:#dbeafe;color:#2563eb}.status-badge svg{width:18px;height:18px}.already-placed p,.already-found p{color:#6b7280;margin:0 0 20px}.rock-description{background:#f9fafb;border-radius:12px;padding:16px;margin-bottom:20px}.rock-description p{color:#4b5563;font-size:14px;line-height:1.6;margin:0}.btn-primary,.btn-secondary{width:100%;padding:14px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;margin-bottom:10px}.btn-primary{background:#3b82f6;color:#fff;border:none}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-back{width:100%;padding:12px;background:transparent;border:none;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:color .15s}.btn-back:hover{color:#374151}.placement-map-container{display:flex;flex-direction:column;gap:16px}.map-wrapper{width:100%;height:300px;border-radius:16px;overflow:hidden;border:2px solid #e5e7eb;position:relative}.map-instruction{font-size:14px;color:#6b7280;margin:0;text-align:center}.map-actions{display:flex;flex-direction:column;gap:8px}.confirm-btn{background:#16a34a}.confirm-btn:hover{background:#15803d}@media(max-width:480px){.scan-page{padding:0;align-items:flex-end}.scan-content,.scan-error,.scan-success{border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto}}.onboarding-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);overflow-y:auto}.onboarding-card{width:100%;max-width:600px;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 20px 60px #0000004d;margin:1rem 0}.onboarding-icon{font-size:4rem;text-align:center;margin-bottom:1rem}.onboarding-icon.success{color:#38a169}.onboarding-title{font-size:1.75rem;font-weight:700;color:#1a202c;margin:0 0 1rem;text-align:center}.onboarding-text{font-size:1rem;color:#718096;line-height:1.6;margin:0 0 1.5rem;text-align:center}.onboarding-feature-list{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.feature-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f7fafc;border-radius:8px}.feature-icon{font-size:1.5rem;flex-shrink:0}.feature-item span:last-child{color:#2d3748;font-size:.95rem}.onboarding-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem}.tutorial-steps{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.tutorial-step{display:flex;gap:1rem}.step-number{flex-shrink:0;width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.step-content h3{font-size:1.1rem;font-weight:700;color:#1a202c;margin:0 0 .5rem}.step-content p{font-size:.95rem;color:#718096;line-height:1.5;margin:0}.rarity-info{background:#f7fafc;border-radius:12px;padding:1.5rem;margin:2rem 0}.rarity-info h3{font-size:1.1rem;font-weight:700;color:#1a202c;margin:0 0 1rem;text-align:center}.rarity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem;margin:1rem 0}.rarity-badge{padding:.75rem;border-radius:8px;text-align:center;font-weight:700;font-size:.85rem;display:flex;flex-direction:column;gap:.25rem}.rarity-badge.common{background:#e2e8f0;color:#4a5568}.rarity-badge.uncommon{background:#c6f6d5;color:#22543d}.rarity-badge.rare{background:#bee3f8;color:#1a365d}.rarity-badge.epic{background:#e9d8fd;color:#44337a}.rarity-badge.legendary{background:#feebc8;color:#7c2d12}.rarity-name{font-size:.95rem}.rarity-desc{font-size:.75rem;font-weight:500;opacity:.8}.rarity-note{font-size:.85rem;color:#718096;text-align:center;margin:1rem 0 0;line-height:1.5}.permissions-list{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.permission-card{display:flex;gap:1rem;padding:1.5rem;background:#f7fafc;border-radius:12px;border:2px solid #e2e8f0}.permission-icon{font-size:2rem;flex-shrink:0}.permission-content h3{font-size:1.1rem;font-weight:700;color:#1a202c;margin:0 0 .5rem}.permission-content p{font-size:.9rem;color:#718096;line-height:1.5;margin:0}.permission-status{margin-top:.75rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;display:inline-block}.permission-status.granted{background:#c6f6d5;color:#22543d}.permission-status.denied{background:#fed7d7;color:#742a2a}.permission-note{background:#eef2ff;border-radius:8px;padding:1rem;margin:1.5rem 0}.permission-note h3{font-size:1rem;font-weight:700;color:#1a202c;margin:0 0 .75rem}.permission-note p,.permission-note ul{font-size:.9rem;color:#4a5568;line-height:1.6;margin:.5rem 0}.permission-note ul{padding-left:1.5rem}.permission-warning{background:#fef5e7;border:2px solid #f7dc6f;border-radius:8px;padding:1rem;margin:1rem 0}.permission-warning h3{font-size:1rem;font-weight:700;color:#7d6608;margin:0 0 .5rem}.permission-warning p{font-size:.9rem;color:#7d6608;line-height:1.5;margin:0}.permissions-status{background:#f7fafc;border-radius:12px;padding:1.5rem;margin:1.5rem 0}.permissions-status h3,.quick-tips h3,.next-steps h3,.community-note h3{font-size:1rem;font-weight:700;color:#1a202c;margin:0 0 1rem}.permission-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #e2e8f0}.permission-item:last-child{border-bottom:none}.permission-item span:first-child{font-size:1.25rem}.quick-tips,.next-steps{margin:2rem 0}.quick-tips ul,.next-steps ol{padding-left:1.5rem;margin:.5rem 0 0}.quick-tips li,.next-steps li{font-size:.95rem;color:#4a5568;line-height:1.6;margin:.5rem 0}.community-note{background:#eef2ff;border-radius:12px;padding:1.5rem;margin:2rem 0}.community-note p{font-size:.95rem;color:#4a5568;line-height:1.6;margin:0}.houses-grid{display:grid;gap:1rem;margin:2rem 0}.house-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;text-align:center}.house-icon{font-size:3rem;margin-bottom:.75rem}.house-card h3{font-size:1.1rem;font-weight:700;color:#1a202c;margin:0 0 .5rem}.house-card p{font-size:.9rem;color:#718096;line-height:1.5;margin:0}.creator-tips{background:#f7fafc;border-radius:12px;padding:1.5rem;margin:2rem 0}.creator-tips h3{font-size:1rem;font-weight:700;color:#1a202c;margin:0 0 1rem}.creator-tips ul{padding-left:1.5rem;margin:0}.creator-tips li{font-size:.9rem;color:#4a5568;line-height:1.6;margin:.5rem 0}@media(min-width:768px){.onboarding-card{padding:2.5rem}.onboarding-title{font-size:2rem}.houses-grid{grid-template-columns:repeat(2,1fr)}.rarity-grid{grid-template-columns:repeat(5,1fr)}}@media(max-width:480px){.onboarding-container{padding:.5rem}.onboarding-card{padding:1.5rem;border-radius:12px}.onboarding-title{font-size:1.5rem}.tutorial-step,.permission-card{flex-direction:column;align-items:center;text-align:center}.rarity-grid{grid-template-columns:repeat(2,1fr)}}@media(hover:none)and (pointer:coarse){.onboarding-actions button{min-height:48px}}.rock-page{min-height:100vh;background:#f8fafc}.rock-page.loading,.rock-page.error{display:flex;align-items:center;justify-content:center}.loading-container,.error-container{text-align:center;padding:40px}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:64px;margin-bottom:16px}.error-container h1{font-size:24px;color:#1e293b;margin:0 0 8px}.error-container p{color:#64748b;margin:0 0 24px}.back-button{display:inline-block;padding:12px 24px;background:#3b82f6;color:#fff;text-decoration:none;border-radius:8px;font-weight:600}.back-button:hover{background:#2563eb}.rock-header{padding:16px 20px;background:#fff;border-bottom:1px solid #e2e8f0}.back-link{display:inline-flex;align-items:center;gap:8px;color:#64748b;text-decoration:none;font-weight:500;font-size:14px}.back-link:hover{color:#3b82f6}.rock-content{max-width:600px;margin:0 auto;padding:24px 20px}.rock-image-container{position:relative;border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 4px 12px #0000001a;margin-bottom:24px}.rock-image{width:100%;aspect-ratio:4/3;object-fit:cover}.rock-placeholder{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:80px}.rarity-badge{position:absolute;top:16px;right:16px;padding:6px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.rock-info{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d;margin-bottom:24px}.rock-name{font-size:28px;font-weight:700;color:#1e293b;margin:0 0 8px}.house-link{display:inline-block;font-size:14px;font-weight:600;text-decoration:none;margin-bottom:16px}.house-link:hover{text-decoration:underline}.rock-description{color:#475569;line-height:1.6;margin:0 0 20px}.rock-stats{display:flex;gap:24px;padding:16px 0;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;margin-bottom:20px}.stat{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:18px;font-weight:700;color:#1e293b;text-transform:capitalize}.discovery-info,.not-found-info{padding:16px;border-radius:12px;background:#f1f5f9}.discovery-info p,.not-found-info p{margin:0;color:#475569;font-size:14px}.not-found-info .hint{margin-top:8px;color:#94a3b8;font-size:13px}.rock-actions{display:flex;gap:12px}.action-button{flex:1;padding:14px 20px;border-radius:12px;font-size:15px;font-weight:600;text-align:center;text-decoration:none;border:none;cursor:pointer;transition:all .2s}.action-button.primary{background:#3b82f6;color:#fff}.action-button.primary:hover{background:#2563eb}.action-button.secondary{background:#fff;color:#475569;border:1px solid #e2e8f0}.action-button.secondary:hover{background:#f8fafc;border-color:#cbd5e1}@media(max-width:480px){.rock-content{padding:16px}.rock-name{font-size:24px}.rock-stats{gap:16px}.action-button{padding:12px 16px;font-size:14px}}#root{height:100vh;width:100vw;margin:0;padding:0;overflow:hidden}.starter-instructions{color:light-dark(#333,#ccc);text-align:left;max-width:800px}.starter-instructions p{text-align:left}.starter-instructions code{display:inline-block;padding:0 .3em;color:light-dark(#000,#fff);background-color:light-dark(#eee,#3a3a3a);border-radius:4px;font-family:Courier New,monospace;font-size:.9em}.starter-instructions ol{line-height:1.8}.starter-instructions li{margin-bottom:12px}.starter-instructions h2{margin-top:24px;margin-bottom:12px}.starter-instructions a{color:#3b82f6;text-decoration:none}.starter-instructions a:hover{text-decoration:underline}.achievement-unlock-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:backdropFadeIn .3s ease}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.confetti-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1001}.achievement-unlock-modal{position:relative;background:linear-gradient(180deg,#1f2937,#111827);border-radius:24px;padding:2.5rem 2rem;max-width:400px;width:100%;text-align:center;border:2px solid var(--rarity-primary);box-shadow:var(--rarity-glow),0 25px 50px -12px #00000080;transform:scale(.8);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);z-index:1002;overflow:visible}.achievement-unlock-modal.show{transform:scale(1);opacity:1}.modal-glow-ring{position:absolute;top:50%;left:50%;width:200%;height:200%;border:2px solid var(--rarity-primary);border-radius:50%;transform:translate(-50%,-50%);opacity:0;animation:glowRingExpand 1.5s ease-out forwards;pointer-events:none}.modal-glow-ring.secondary{animation-delay:.2s;border-width:1px}@keyframes glowRingExpand{0%{width:0;height:0;opacity:.8}to{width:300%;height:300%;opacity:0}}.modal-close-btn{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border:none;background:#ffffff1a;color:#9ca3af;font-size:1.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.modal-close-btn:hover{background:#fff3;color:#fff}.modal-header{margin-bottom:1.5rem}.unlock-label{display:inline-block;padding:.5rem 1.25rem;background:var(--rarity-gradient);border-radius:20px;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#fff;animation:labelPulse .5s ease-out}@keyframes labelPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.modal-icon-wrapper{position:relative;width:120px;height:120px;margin:0 auto 1.5rem}.icon-burst{position:absolute;top:50%;left:50%;width:100%;height:100%;transform:translate(-50%,-50%);background:var(--rarity-gradient);border-radius:50%;filter:blur(30px);opacity:.5;animation:burstPulse 2s ease-in-out infinite}@keyframes burstPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.3}}.achievement-icon-large{position:relative;width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #0000004d,inset 0 -4px 10px #0003;animation:iconBounce .6s cubic-bezier(.34,1.56,.64,1);z-index:1}@keyframes iconBounce{0%{transform:scale(0)}60%{transform:scale(1.15)}to{transform:scale(1)}}.icon-emoji-large{font-size:4rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.icon-particles{position:absolute;top:50%;left:50%;width:100%;height:100%;pointer-events:none}.particle{position:absolute;width:8px;height:8px;background:var(--rarity-primary);border-radius:50%;top:50%;left:50%;animation:particleFloat 1s ease-out forwards;animation-delay:calc(var(--index) * .05s)}@keyframes particleFloat{0%{transform:translate(-50%,-50%) scale(0);opacity:1}to{transform:translate(calc(-50% + cos(var(--index) * 45deg)*80px),calc(-50% + sin(var(--index) * 45deg)*80px)) scale(1);opacity:0}}.particle:nth-child(1){--angle: 0deg;transform:translate(-50%,-50%) translate(80px)}.particle:nth-child(2){--angle: 45deg;transform:translate(-50%,-50%) translate(56px,56px)}.particle:nth-child(3){--angle: 90deg;transform:translate(-50%,-50%) translateY(80px)}.particle:nth-child(4){--angle: 135deg;transform:translate(-50%,-50%) translate(-56px,56px)}.particle:nth-child(5){--angle: 180deg;transform:translate(-50%,-50%) translate(-80px)}.particle:nth-child(6){--angle: 225deg;transform:translate(-50%,-50%) translate(-56px,-56px)}.particle:nth-child(7){--angle: 270deg;transform:translate(-50%,-50%) translateY(-80px)}.particle:nth-child(8){--angle: 315deg;transform:translate(-50%,-50%) translate(56px,-56px)}.modal-content{margin-bottom:2rem}.achievement-title{margin:0 0 .75rem;font-size:1.75rem;font-weight:800;color:#f9fafb;animation:titleFadeIn .4s ease .2s both}@keyframes titleFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.achievement-desc{margin:0 0 1.25rem;font-size:1rem;color:#9ca3af;line-height:1.5;animation:titleFadeIn .4s ease .3s both}.achievement-meta{display:flex;align-items:center;justify-content:center;gap:1rem;animation:titleFadeIn .4s ease .4s both}.rarity-tag{padding:.35rem .85rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}.points-earned{font-size:1.1rem;font-weight:700;color:var(--rarity-primary)}.modal-actions{display:flex;flex-direction:column;gap:.75rem;animation:titleFadeIn .4s ease .5s both}.modal-btn{padding:.875rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;border:none}.modal-btn.primary{color:#fff;box-shadow:0 4px 12px #0000004d}.modal-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006}.modal-btn.secondary{background:#ffffff1a;color:#9ca3af}.modal-btn.secondary:hover{background:#ffffff26;color:#fff}.achievement-unlock-modal.legendary{animation:legendaryShimmer 3s ease-in-out infinite}@keyframes legendaryShimmer{0%,to{box-shadow:0 0 30px #ffb30066,0 25px 50px -12px #00000080}50%{box-shadow:0 0 60px #ffb30099,0 25px 50px -12px #00000080}}.achievement-unlock-modal.epic .icon-burst{animation:burstPulse 1.5s ease-in-out infinite}@media(max-width:480px){.achievement-unlock-modal{padding:2rem 1.5rem;margin:1rem}.modal-icon-wrapper{width:100px;height:100px}.icon-emoji-large{font-size:3rem}.achievement-title{font-size:1.5rem}.achievement-desc{font-size:.9rem}}@media(prefers-color-scheme:light){.achievement-unlock-modal-backdrop{background:#000000b3}.achievement-unlock-modal{background:linear-gradient(180deg,#fff,#f9fafb)}.modal-close-btn{background:#0000000d;color:#6b7280}.modal-close-btn:hover{background:#0000001a;color:#111827}.achievement-title{color:#111827}.achievement-desc{color:#6b7280}.modal-btn.secondary{background:#0000000d;color:#6b7280}.modal-btn.secondary:hover{background:#0000001a;color:#111827}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;width:100%;height:100%;min-height:100vh;overflow-x:hidden}body{background-color:#f8fafc;background-image:radial-gradient(circle at 50% 0%,#e0e7ff,#f8fafc 80%);background-attachment:fixed;background-size:cover}h1,h2,h3,h4,h5,h6{font-family:Fredoka,sans-serif;letter-spacing:.025em}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;font-family:inherit;cursor:pointer}input,textarea,select{background-color:#fff;color:#1a1a1a;border:1px solid #d1d5db}input::placeholder,textarea::placeholder{color:#9ca3af}input:focus,textarea:focus,select:focus{outline:none;border-color:#3b82f6}
