.login-bar button[data-v-8650bbd4],.login-bar input[data-v-8650bbd4]{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:.375rem}.login-bar button[data-v-8650bbd4]{background:#f9fafb;cursor:pointer}.login-bar button[data-v-8650bbd4]:hover{background:#f3f4f6}.google-btn[data-v-8650bbd4]{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;border:1px solid #dadce0;border-radius:6px;color:#3c4043;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.google-btn[data-v-8650bbd4]:hover{box-shadow:0 1px 2px rgba(60,64,67,.3),0 1px 3px 1px rgba(60,64,67,.15)}.google-icon[data-v-8650bbd4]{width:18px;height:18px}*{margin:0;padding:0;box-sizing:border-box}body,html{height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f5f7fa}#app{height:100vh;display:flex;flex-direction:column;padding-top:40px}.app-header{background:linear-gradient(87deg,#ff0303,#0008ff);color:#fff;padding:1rem 0 1rem 2rem;box-shadow:0 2px 10px rgba(0,0,0,.1);height:80px;display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:1000}.app-header h1{font-size:1.5rem;font-weight:600}.navbar{background:#1e293b;color:#e2e8f0;padding:1rem;width:320px;height:calc(100vh - 80px);display:flex;flex-direction:column;gap:1rem;box-shadow:2px 0 5px rgba(0,0,0,.2);border-right:1px solid #334155;position:fixed;left:0;top:80px;overflow-y:auto;font-size:1rem}.control-section{border-bottom:1px solid #334155;padding-bottom:1rem}.section-header{font-weight:600;margin-bottom:.8rem;color:#f1f5f9}.engine-info{font-size:.8rem;color:#94a3b8}.nav-buttons{display:flex;gap:.5rem;border-bottom:1px solid #334155;padding-bottom:1rem}.nav-btn{padding:.5rem .8rem;background:transparent;border:1px solid #475569;color:#e2e8f0;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s}.nav-btn.active{border-color:#64748b}.nav-btn.active,.nav-btn:hover{background:#334155}.action-buttons{display:flex;gap:.5rem;border-bottom:1px solid #334155;padding-bottom:1rem}.dashboard{padding:20px 24px;box-shadow:0 4px 12px rgba(0,0,0,.1);font-family:Sarabun,sans-serif;max-width:320px;color:#333}.dashboard>div:first-child{font-size:1.25rem;font-weight:700;margin-bottom:12px;color:#1e40af;border-bottom:2px solid #e5e7eb;padding-bottom:6px}.dashboard>div:last-child{line-height:1.6;font-size:.95rem}.dashboard>div:last-child br{margin-bottom:6px}.flex-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,130px));gap:5px;margin-bottom:5px}.dashboard{background:#fff;border-radius:16px;padding:15px 10px;box-shadow:0 8px 25px rgba(0,0,0,.15);transition:all .3s ease;position:relative;overflow:hidden}.dashboard:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#4facfe,#00f2fe)}.dashboard:nth-child(2):before{background:linear-gradient(90deg,#43e97b,#38f9d7)}.dashboard:hover{transform:translateY(-8px);box-shadow:0 15px 35px rgba(0,0,0,.2)}.dashboard-number{font-size:1.3rem;font-weight:800;color:#2d3748;margin-bottom:8px;text-align:center;display:block}.dashboard-label{font-size:.8rem!important;color:#718096;font-weight:500;line-height:1.4;text-align:center}.dashboard-icon{position:absolute;top:20px;right:20px;font-size:2rem;opacity:.1}.land-plots .dashboard-icon:before{content:"🏞️"}.owners .dashboard-icon:before{content:"👥"}.area .dashboard-icon:before{content:"📐"}.value .dashboard-icon:before{content:"💰"}.highlight{font-size:.8rem!important;color:#4299e1;font-weight:700;text-align:center}@media (max-width:768px){.header h1{font-size:2rem}.dashboard{padding:25px 20px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.dashboard{animation:fadeInUp .6s ease forwards}.dashboard:first-child{animation-delay:.1s}.dashboard:nth-child(2){animation-delay:.2s}.dashboard:nth-child(3){animation-delay:.3s}.dashboard:nth-child(4){animation-delay:.4s}.form-select{width:100%;padding:.5rem;margin-bottom:.8rem;background:#334155;border:1px solid #475569;border-radius:4px;color:#e2e8f0;font-size:.9rem}.form-select:focus{outline:none;border-color:#3b82f6}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem;cursor:pointer}.checkbox-label input[type=checkbox]{display:none}.checkmark{width:16px;height:16px;background:#dc2626;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.3rem;font-size:.9rem;color:#f1f5f9}.form-input{width:100%;padding:.5rem;background:#334155;border:1px solid #475569;border-radius:4px;color:#e2e8f0;font-size:.9rem}.form-input:focus{outline:none;border-color:#3b82f6}.form-input::-moz-placeholder{color:#64748b}.form-input::placeholder{color:#64748b}.search-input{width:100%;padding:.8rem;border:1px solid #d1d5db;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.number-input{width:60px;padding:.3rem;background:#334155;border:1px solid #475569;border-radius:3px;color:#e2e8f0;font-size:.8rem}.number-input:focus{outline:none;border-color:#3b82f6}.price-input{flex:1;padding:.6rem;border:1px solid #d1d5db;border-radius:4px;font-size:.8rem}.price-input:focus{outline:none;border-color:#3b82f6}.btn{padding:.4rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s}.btn-secondary{background:#64748b;color:#fff}.btn-info{background:#06b6d4;color:#fff}.btn-success{background:#10b981;color:#fff}.btn-danger{background:#ef4444;color:#fff}.btn-full{width:100%}.btn:hover{opacity:.8}.button-group{display:flex;gap:.5rem;margin-bottom:.8rem}.close-btn{background:none;font-size:1.5rem;color:#6b7280;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:#e5e7eb;color:#374151}.btn-sm{padding:6px 12px;font-size:13px}.btn-primary{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.btn-primary:disabled{background:#6b7280;border-color:#6b7280;cursor:not-allowed}.opacity-control{display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}.slider{flex:1;height:4px;background:#475569;border-radius:2px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#dc2626;border-radius:50%;cursor:pointer}.opacity-value{font-size:.8rem;color:#94a3b8}.snap-section{border-bottom:1px solid #334155;padding-bottom:1rem}.snap-controls{display:flex;flex-direction:column;gap:.5rem}.snap-row{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.form-section{flex:1}.form-section h3{font-size:1.5rem;margin-bottom:.5rem;color:#f1f5f9}.form-subtitle{font-size:1rem;color:#94a3b8;margin-bottom:.8rem}.section-divider{height:1px;background:#334155;margin:1.5rem 0}.land-list{max-height:200px;overflow-y:auto}.land-item{background:#334155;padding:.8rem;margin-bottom:.5rem;border-radius:4px;border-left:3px solid #3b82f6}.land-owner{font-weight:600;color:#f1f5f9;margin-bottom:.3rem}.land-details{font-size:.8rem;color:#94a3b8}.no-data{text-align:center;color:#64748b;font-style:italic;padding:1rem}.main-content{flex:1;display:flex;margin-left:320px;height:calc(100vh - 80px)}.map-container{width:100%;height:100%;position:relative;background-color:#f8fafc}#map{border-radius:0}.map-controls{position:absolute;right:15px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:200}.control-btn{width:45px;height:45px;background:#fff;border:2px solid #e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.15)}.control-btn:hover{background:#f8fafc;border-color:#3b82f6;transform:scale(1.05)}.control-btn svg{width:20px;height:20px;color:#374151}.control-btn:hover svg{color:#3b82f6}.filters-panel,.layers-panel,.search-panel{position:absolute;right:80px;top:250px;width:300px;background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:300;border:1px solid #e5e7eb}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb;background:#f8fafc;border-radius:8px 8px 0 0}.panel-header h3{margin:0;font-size:1rem;color:#1f2937}.filters-panel,.search-panel{padding:1rem}.filter-group{margin-bottom:1rem}.filter-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.9rem}.price-range{display:contents;align-items:center;gap:.5rem}.layers-panel{padding:1rem}.layer-item{margin-bottom:.8rem}.layer-item:last-child{margin-bottom:0}.layer-item .checkbox-label{margin-bottom:0;color:#374151}.layer-item .checkmark{background:#3b82f6;width:18px;height:18px}@media (max-width:768px){.navbar{width:280px}.main-content{margin-left:280px}.map-controls{right:10px;gap:8px}.control-btn{width:40px;height:40px}.control-btn svg{width:18px;height:18px}.filters-panel,.layers-panel,.search-panel{right:60px;width:250px}}@media (max-width:480px){.navbar{width:100%;height:50vh;position:relative;top:0}.main-content{margin-left:0;flex-direction:column}.map-container{width:100%;height:50vh}#app{padding-top:0}.app-header{position:relative}.map-controls{right:5px;top:auto;bottom:20px;transform:none;flex-direction:row;justify-content:center;gap:6px}.control-btn{width:35px;height:35px}.control-btn svg{width:16px;height:16px}.filters-panel,.layers-panel,.search-panel{right:10px;left:10px;width:auto;top:10px}}.p2p-btn{position:relative}.p2p-btn.has-notification{animation:pulse 2s infinite}.notification-badge{top:-5px;right:-5px;background:#ef4444;border-radius:50%;width:18px;height:18px;align-items:center;justify-content:center;font-size:10px;font-weight:700}.chat-popup,.notification-badge{position:absolute;color:#fff;display:flex}.chat-popup{right:16px;bottom:80px;width:360px;max-width:90vw;background:#1f2937;border-radius:12px;overflow:hidden;box-shadow:0 10px 25px rgba(0,0,0,.4);flex-direction:column;z-index:1000}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#111827;border-bottom:1px solid #374151}.chat-title h3{margin:0;font-size:16px;color:#f9fafb}.online-users{font-size:12px;color:#9ca3af;display:flex;align-items:center;gap:4px}.online-indicator{width:8px;height:8px;background:#10b981;border-radius:50%;display:inline-block}.user-profile{padding:12px 16px;background:#374151;display:flex;gap:8px;align-items:center}.profile-input{flex:1;padding:8px 12px;border-radius:6px;border:1px solid #4b5563;background:#1f2937;color:#f9fafb;font-size:14px}.chat-body{height:300px;overflow-y:auto;padding:12px 16px;background:#0f172a;scroll-behavior:smooth}.chat-body::-webkit-scrollbar{width:6px}.chat-body::-webkit-scrollbar-track{background:#1e293b}.chat-body::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.chat-msg{display:flex;margin-bottom:12px;animation:fadeIn .3s ease-in}.chat-msg.me{justify-content:flex-end}.chat-msg.system{justify-content:center}.chat-msg .bubble{max-width:75%;background:#374151;padding:8px 12px;border-radius:12px;word-wrap:break-word}.chat-msg.me .bubble{background:#3b82f6}.chat-msg.system .bubble{background:#6b7280;font-style:italic;font-size:13px}.chat-msg .meta{font-size:11px;color:#9ca3af;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}.timestamp{font-size:10px;opacity:.7}.chat-msg .text{line-height:1.4}.no-messages{text-align:center;color:#6b7280;font-style:italic;padding:40px 20px}.typing-indicator{padding:8px 16px;background:#1e293b;border-top:1px solid #374151;font-size:12px;color:#9ca3af;display:flex;align-items:center;gap:8px}.typing-dots{display:flex;gap:2px}.typing-dots span{width:4px;height:4px;background:#6b7280;border-radius:50%;animation:typing 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.chat-input-row{display:flex;gap:8px;padding:12px 16px;background:#111827;border-top:1px solid #374151}.chat-input{flex:1;padding:8px 12px;border-radius:6px;border:1px solid #4b5563;background:#1f2937;color:#f9fafb;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#3b82f6}.chat-input:disabled{opacity:.5;cursor:not-allowed}.send-btn{padding:8px 16px;white-space:nowrap}.close-btn{background:transparent;border:none;color:#9ca3af;font-size:18px;cursor:pointer;padding:4px;border-radius:4px;transition:color .2s}.close-btn:hover{color:#f9fafb}@keyframes pulse{0%,to{box-shadow:0 0 0 0 rgba(59,130,246,.7)}50%{box-shadow:0 0 0 10px rgba(59,130,246,0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}@media (max-width:768px){.chat-popup{width:calc(100vw - 32px);right:65px;bottom:16px}.chat-body{height:250px}}.rooms-head{display:flex;align-items:center;gap:.5rem;margin:.25rem 0 .5rem}.rooms-title{font-weight:600}.badge{background:#0ea5e9;color:#fff;border-radius:999px;padding:0 .5rem;font-size:.8rem}.badge.warn{background:#ef4444}.user-list{display:flex;flex-wrap:wrap;gap:.5rem}.user-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .6rem;border-radius:999px;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.12);cursor:pointer}.user-pill:hover{background:hsla(0,0%,100%,.12)}.user-pill .dot{width:8px;height:8px;border-radius:50%}.user-pill .dot.online{background:#22c55e}.user-pill .name{white-space:nowrap}.chat-subheader{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:.5rem}.chat-subheader .peer-name{font-weight:600;overflow:hidden;text-overflow:ellipsis}.room-list{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem}.room-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;border:1px solid hsla(0,0%,100%,.12);border-radius:.5rem;background:hsla(0,0%,100%,.04);cursor:pointer}.room-item:hover{background:hsla(0,0%,100%,.08)}.room-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}