*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100vw;height:100vh}.app{width:100vw;height:100vh;overflow:hidden}.header{position:fixed;top:0;left:0;right:0;z-index:1000;background-color:#2c3e50b3;color:#fff;padding:.6rem 1.5rem;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.display-options-dropdown{position:relative}.display-options-btn{background-color:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.display-options-btn:hover{background-color:#ffffff1a;border-color:#ffffff80}.display-options-menu{position:absolute;top:100%;left:0;background-color:#fff;border-radius:4px;box-shadow:0 4px 12px #00000026;padding:.5rem;min-width:120px;z-index:1001;margin-top:4px;display:flex;flex-direction:column;gap:.5rem}.display-options-menu label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#333;cursor:pointer;white-space:nowrap}.display-options-menu input[type=checkbox]{cursor:pointer}.header h1{margin:0;font-size:1.2rem}.header-search{display:flex;gap:6px;align-items:center;position:relative}.header-search-input{padding:6px 10px;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#333;font-size:13px;width:180px;outline:none;transition:all .2s}.header-search-input::placeholder{color:#999}.header-search-input:focus{border-color:#3498db}.header-search-btn{padding:6px 12px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:background-color .2s}.header-search-btn:hover{background-color:#2980b9}.header-search-btn:disabled{background-color:#95a5a6;cursor:not-allowed}.header-search-clear-btn{padding:.5rem .75rem;border:none;border-radius:4px;background-color:#e74c3c;color:#fff;cursor:pointer;font-size:.85rem}.header-search-clear-btn:hover{background-color:#c0392b}.search-results-list{position:absolute;top:100%;left:0;right:0;background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:1001;margin-top:4px}.search-result-item{display:flex;align-items:center;padding:.75rem;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:#f5f5f5}.search-result-index{width:24px;height:24px;background-color:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:.75rem;flex-shrink:0}.search-result-item:first-child .search-result-index{background-color:#e74c3c}.search-result-content{flex:1;min-width:0}.search-result-name{font-size:.85rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-address{font-size:.75rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.search-result-distance{font-size:.75rem;color:#999;margin-left:.5rem;white-space:nowrap}.map-switch{display:flex;gap:.5rem}.map-switch button{padding:.5rem 1rem;border:none;border-radius:4px;background-color:#2c3e50;color:#fff;cursor:pointer;transition:all .3s ease}.map-switch button:hover{background-color:#34495e}.map-switch button.active{background-color:#3498db}.map-container{width:100%;height:100vh;position:relative}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:2px;z-index:1000}.zoom-btn{width:40px;height:40px;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:24px;font-weight:700;color:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:all .2s;-webkit-user-select:none;user-select:none}.zoom-btn:hover{background-color:#f0f0f0;box-shadow:0 2px 6px #0000004d}.zoom-btn:active{background-color:#e0e0e0;box-shadow:0 1px 2px #0003}.zoom-btn.zoom-in{border-bottom-left-radius:0;border-bottom-right-radius:0}.zoom-btn.zoom-out{border-top-left-radius:0;border-top-right-radius:0}.grid-polygon{stroke:#3498db;stroke-width:2;fill:#3498db33}.grid-label{background-color:#ffffffe6;border:1px solid #3498db;border-radius:4px;padding:.25rem .5rem;font-size:12px;font-weight:700}.anchor-point{width:12px;height:12px;background-color:#27ae60;border-radius:50%;border:2px solid white;box-shadow:0 0 4px #0000004d}.control-panel{position:absolute;top:60px;right:20px;background-color:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:.75rem;width:260px;z-index:100}.control-panel h3{margin-top:0;margin-bottom:1rem;font-size:1rem;color:#333}.control-panel .form-group{margin-bottom:1rem}.control-panel label{display:block;margin-bottom:.5rem;font-size:.875rem;color:#666}.control-panel input,.control-panel select,.control-panel button{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.875rem}.control-panel button{background-color:#3498db;color:#fff;border:none;cursor:pointer;transition:background-color .3s ease}.control-panel button:hover{background-color:#2980b9}.control-panel button:active{background-color:#1f618d}.grid-list{position:absolute;top:80px;left:20px;background-color:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:.75rem;width:auto;min-width:320px;max-width:500px;display:flex;flex-direction:column;z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translate(0)}.grid-list.collapsed{transform:translate(-150%);opacity:0;pointer-events:none}.grid-list-drawer-handle{position:absolute;top:80px;left:0;background-color:#fff;padding:10px 12px 10px 8px;border-top-right-radius:20px;border-bottom-right-radius:20px;box-shadow:2px 2px 5px #00000026;cursor:pointer;z-index:99;display:flex;align-items:center;gap:6px;transition:all .2s ease;border:1px solid #e0e0e0;border-left:none}.grid-list-drawer-handle:hover{background-color:#f8f9fa;padding-right:16px;box-shadow:3px 3px 8px #0003}.drawer-icon{font-size:1.2rem}.drawer-text{font-size:.9rem;font-weight:500;color:#333}.grid-list.collapsed .grid-list-header h3,.grid-list.collapsed .grid-list-buttons,.grid-list.collapsed .grid-controls,.grid-list.collapsed .grid-list-content,.grid-list-toggle{display:none}.grid-list-hide-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#666;display:flex;align-items:center;justify-content:center}.grid-list-hide-btn:hover{background-color:#0000000d;color:#333}.poi-drawer{position:absolute;top:150px;left:20px;background-color:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:.75rem;width:200px;z-index:99;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translate(0)}.poi-drawer.collapsed{transform:translate(-150%);opacity:0;pointer-events:none}.poi-drawer-handle{position:absolute;top:150px;left:0;background-color:#fff;padding:10px 12px 10px 8px;border-top-right-radius:20px;border-bottom-right-radius:20px;box-shadow:2px 2px 5px #00000026;cursor:pointer;z-index:98;display:flex;align-items:center;gap:6px;transition:all .2s ease;border:1px solid #e0e0e0;border-left:none}.poi-drawer-handle:hover{background-color:#f8f9fa;padding-right:16px;box-shadow:3px 3px 8px #0003}.poi-options{display:flex;flex-direction:column;gap:8px}.poi-option-item{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:#333}.poi-option-item:hover{color:#3498db}.grid-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.grid-list-header h3{margin:0;font-size:.9rem;color:#333}.grid-list-buttons{display:flex;gap:.4rem}.show-all-grids-btn,.hide-all-grids-btn{padding:.3rem .5rem;border:none;border-radius:4px;color:#fff;cursor:pointer;transition:all .3s ease;font-size:10px}.show-all-grids-btn{background-color:#3498db}.show-all-grids-btn:hover{background-color:#2980b9}.hide-all-grids-btn{background-color:#95a5a6}.hide-all-grids-btn:hover{background-color:#7f8c8d}.grid-controls{display:flex;gap:.5rem;margin-bottom:0}.search-box{flex:1;min-width:0}.search-box input{width:100%;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem}.tag-filter-box{min-width:80px}.tag-filter-box select{width:100%;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem;background-color:#fff;cursor:pointer;height:32px}.tag-filter-box select:focus{outline:none;border-color:#3498db}.staff-filter-box{min-width:100px}.staff-filter-box select{width:100%;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem;background-color:#fff;cursor:pointer;height:32px}.staff-filter-box select:focus{outline:none;border-color:#3498db}.grid-list-content{display:none}.grid-list h3{margin-top:0;margin-bottom:1rem;font-size:1rem;color:#333}.sort-box{width:120px}.sort-box select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.875rem;background-color:#fff}.grid-item{width:calc(50% - 4px);padding:.6rem;cursor:pointer;transition:all .2s ease;border-radius:8px;border:1px solid #d0d0d0;background-color:#fff;box-sizing:border-box}.grid-item:hover{background-color:#f8f9fa;border-color:#a0a0a0;box-shadow:0 2px 8px #0000001a}.grid-item-content{width:100%;cursor:pointer}.grid-item-content .grid-name{font-weight:700;margin-bottom:.25rem;text-align:center;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-item-row{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.2rem}.grid-item-content .grid-tag{display:inline-block;padding:.1rem .4rem;border-radius:10px;font-size:.65rem;font-weight:700}.grid-item-content .assigned-staff{font-size:.65rem;color:#3498db}.grid-item-content .anchor-count{font-size:.65rem;color:#666;margin-top:.2rem;text-align:center}.grid-item-content .grid-distance{font-size:.6rem;color:#888;margin-top:.15rem;text-align:center}.grid-item-content .grid-remark{font-size:.6rem;color:#666;margin-top:.15rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 .2rem}.grid-item.selected .grid-remark{color:#bdc3c7}.grid-item.selected .grid-distance{color:#aaa}.grid-item.selected{background-color:#2c3e50;border-color:#1a252f;box-shadow:0 4px 12px #2c3e5066}.grid-item.selected .grid-name{color:#fff}.grid-item.selected .assigned-staff{color:#74b9ff}.grid-item.selected .anchor-count{color:#bdc3c7}.grid-item:last-child{border-bottom:none}.empty-message{text-align:center;padding:2rem;color:#666;font-style:italic}.anchor-list{max-height:120px;overflow-y:auto;border:1px solid #eee;border-radius:4px;margin-top:.5rem}.anchor-item{padding:.5rem;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s ease}.anchor-item:hover{background-color:#f5f5f5}.anchor-item.selected{background-color:#e3f2fd;border-left:4px solid #3498db}.anchor-item:last-child{border-bottom:none}.grid-tag{background-color:#95a5a6;color:#fff}.tag-S{background-color:#e74c3c;color:#fff}.tag-A-plus{background-color:#c0392b;color:#fff}.tag-A{background-color:#e67e22;color:#fff}.tag-B-plus{background-color:#f39c12;color:#fff}.tag-B{background-color:#f1c40f;color:#333}.tag-B-minus{background-color:#f7dc6f;color:#333}.tag-C{background-color:#95a5a6;color:#fff}.form-row{display:flex;gap:.75rem;margin-bottom:.6rem;flex-wrap:nowrap}.form-row.form-row-nowrap{flex-wrap:nowrap}.form-row-3col .form-group,.form-row-2col .form-group{flex:1;min-width:0}.form-group{display:flex;flex-direction:column;gap:.15rem}.form-group label{font-size:.8rem;font-weight:500;color:#555}.form-group input,.form-group select{padding:.4rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db}.readonly-input{background-color:#f5f5f5;color:#666;cursor:not-allowed}.input-with-unit{display:flex;align-items:center;gap:.4rem}.input-with-unit input{flex:1}.unit-label{color:#666;font-size:.8rem;font-weight:500;min-width:18px}.input-with-buttons{display:flex;align-items:center;gap:.4rem}.input-with-buttons input{flex:1}.input-btn-group{display:flex;gap:.3rem}.quick-btn{padding:.3rem .6rem;font-size:.75rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background-color .2s}.quick-btn:hover{background-color:#2980b9}.quick-size-btns{display:flex;gap:.25rem;margin-top:.3rem}.quick-btn-sm{padding:.2rem .5rem;font-size:.7rem;background-color:#e8e8e8;color:#333;border:1px solid #ddd;border-radius:3px;cursor:pointer;transition:all .2s}.quick-btn-sm:hover{background-color:#3498db;color:#fff;border-color:#3498db}.form-section-title{font-size:.8rem;font-weight:600;color:#333;margin:.6rem 0 .4rem;padding-bottom:.3rem;border-bottom:1px solid #eee}.quick-move-grid{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.6rem;background-color:#f8f9fa;border-radius:6px}.move-btn-row{display:flex;gap:.4rem;justify-content:center}.move-btn{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:65px}.move-btn-up{background-color:#3498db;color:#fff}.move-btn-up:hover{background-color:#2980b9;transform:translateY(-2px)}.move-btn-down{background-color:#3498db;color:#fff}.move-btn-down:hover{background-color:#2980b9;transform:translateY(2px)}.move-btn-left{background-color:#27ae60;color:#fff}.move-btn-left:hover{background-color:#219a52;transform:translate(-2px)}.move-btn-right{background-color:#27ae60;color:#fff}.move-btn-right:hover{background-color:#219a52;transform:translate(2px)}.grid-modal-large{min-width:600px;max-width:800px}@media (max-width: 600px){.form-row{flex-direction:column;gap:.75rem}.form-row.form-row-nowrap{flex-direction:row;gap:.5rem}.form-row-3col .form-group{width:100%}.form-row.form-row-nowrap .form-group{width:auto;min-width:0}.grid-modal-large{min-width:90vw;max-width:95vw}.move-btn{padding:.5rem .8rem;min-width:70px;font-size:.8rem}}.addresses-container{display:flex;flex-direction:column;gap:.5rem}.address-row{display:flex;gap:.4rem;align-items:center}.address-row .address-input{flex:2;min-width:120px;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem}.address-row .address-rating{width:50px;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem;background-color:#fff}.address-row .address-area,.address-row .address-rent{width:80px;padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem}.remove-address-btn{padding:.2rem .5rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;line-height:1;flex-shrink:0}.remove-address-btn:hover{background-color:#c0392b}.add-address-btn{padding:.4rem .8rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;align-self:flex-start}.add-address-btn:hover{background-color:#2980b9}@media (max-width: 768px){.header{padding:.6rem .8rem;flex-wrap:wrap;gap:.5rem;height:auto;min-height:60px}.header h1{font-size:1rem;white-space:nowrap}.header-search{order:3;width:100%;margin-top:.5rem}.header-search-input{flex:1;width:auto}.map-switch{gap:.3rem}.map-switch button{padding:.4rem .6rem;font-size:.8rem}.display-options-btn{padding:4px 6px;font-size:.8rem}.zoom-controls{bottom:80px;right:10px}.zoom-btn{width:36px;height:36px}.amap-zoom-control,.BMap_stdMpCtrl,.BMap_zlHolder,.anchorBL{display:none!important}.grid-list{top:120px;left:10px;right:10px;width:auto;max-width:none;max-height:calc(100vh - 140px);overflow-y:auto}.grid-controls{flex-wrap:wrap}.search-box{width:100%;flex:1 1 100%}.label-filter-box,.tag-filter-box,.staff-filter-box{flex:1}.poi-drawer{top:180px;left:10px;width:240px;max-height:calc(100vh - 200px);overflow-y:auto}.grid-list-drawer-handle{top:120px}.poi-drawer-handle{top:180px}}.user-profile{position:relative;margin-left:1rem}.user-avatar{width:32px;height:32px;border-radius:50%;background-color:#3498db;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.user-menu{position:absolute;top:100%;right:0;margin-top:8px;background-color:#fff;border-radius:4px;box-shadow:0 2px 10px #0000001a;min-width:150px;z-index:1000;border:1px solid #eee}.user-menu-header{padding:12px;border-bottom:1px solid #eee}.user-role{font-size:.8rem;color:#666;margin-top:4px}.user-menu button{display:block;width:100%;padding:10px 12px;text-align:left;background:none;border:none;cursor:pointer;color:#333;font-size:.9rem}.user-menu button:hover{background-color:#f5f5f5}.user-menu button.logout-btn{color:#e74c3c;border-top:1px solid #eee}.mobile-menu-btn{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;margin-right:.5rem}.header-left{display:flex;align-items:center;gap:1rem}.mobile-menu-header,.mobile-search-toggle,.user-profile-menu-item{display:none}.desktop-user-profile{display:block}@media (max-width: 768px){.header-left{width:100%;justify-content:space-between}.mobile-menu-btn{display:block}.header-search{display:none;width:100%;margin-top:10px;order:3}.header-search.active{display:flex}.map-switch{position:fixed;top:0;right:-260px;width:260px;height:100vh;background-color:#fff;flex-direction:column;padding:20px;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease;z-index:2000;gap:15px}.map-switch.mobile-menu-active{right:0}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #eee;padding-bottom:10px}.mobile-menu-header h3{margin:0;color:#333}.close-menu-btn{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer}.map-switch button{width:100%;text-align:left;padding:12px;background-color:#f8f9fa;color:#333;border-radius:8px;font-size:1rem}.map-switch button.active{background-color:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.mobile-search-toggle{display:block}.desktop-user-profile{display:none}.user-profile-menu-item{display:block;margin-top:20px;border-top:1px solid #eee;padding-top:20px}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:15px}.user-avatar-small{width:32px;height:32px;background-color:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.user-info span{color:#333;font-weight:500}.user-actions{display:flex;flex-direction:column;gap:10px}.user-actions button{background:none;border:none;padding:10px 0;text-align:left;color:#666;font-size:.95rem}.user-actions button.logout-btn{color:#e74c3c}.display-options-dropdown{position:static}.display-options-menu{right:10px;left:auto;width:180px}}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#0f1c2e;position:relative;overflow:hidden}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at bottom,#1b2735 0%,#090a0f 100%);z-index:0}.grid-lines{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(52,152,219,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(52,152,219,.1) 1px,transparent 1px);background-size:50px 50px;background-position:center center;transform:perspective(500px) rotateX(60deg) translateY(100px) scale(2);animation:gridMove 20s linear infinite;opacity:.3}.particles{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle,#3498db 1px,transparent 1px),radial-gradient(circle,#3498db 1px,transparent 1px);background-size:40px 40px;background-position:0 0,20px 20px;animation:particleMove 30s linear infinite;opacity:.1}@keyframes gridMove{0%{transform:perspective(500px) rotateX(60deg) translateY(100px) scale(2);background-position:0 0}to{transform:perspective(500px) rotateX(60deg) translateY(100px) scale(2);background-position:0 50px}}@keyframes particleMove{0%{background-position:0 0,20px 20px}to{background-position:40px 40px,60px 60px}}.login-card{background-color:#fffffff2;padding:2.5rem;border-radius:12px;box-shadow:0 15px 35px #0003;width:100%;max-width:380px;z-index:1;transition:transform .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{color:#3498db;margin-bottom:1rem;display:inline-block}.login-card h2{margin:0 0 .5rem;color:#2c3e50;font-size:1.5rem;font-weight:700}.login-card p{margin:0;color:#7f8c8d;font-size:.9rem}.error-message{background-color:#fff5f5;color:#e74c3c;padding:.75rem 1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem;border:1px solid #ffe0e0}.error-icon{width:18px;height:18px;background-color:#e74c3c;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#34495e;font-weight:600;font-size:.9rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:#95a5a6;display:flex;align-items:center;pointer-events:none}.form-group input.login{width:100%;padding:.85rem 1rem .85rem 2.5rem;border:1px solid #e0e0e0;border-radius:6px;font-size:.95rem;transition:all .2s;box-sizing:border-box;background-color:#fcfcfc;color:#2c3e50}.form-group input::placeholder{color:#bdc3c7}.form-group input:focus{border-color:#3498db;background-color:#fff;outline:none;box-shadow:0 0 0 3px #3498db26}.login-btn{width:100%;padding:.85rem;background-color:#3498db;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem;letter-spacing:1px}.login-btn:hover{background-color:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px #3498db40}.login-btn:active{transform:translateY(0)}.login-btn:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none;box-shadow:none}.loading-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #00000026;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalFadeIn .3s ease-out;border:1px solid #eee}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;background-color:#fafafa;border-radius:12px 12px 0 0}.modal-header h3{margin:0;font-size:1.2rem;color:#2c3e50;font-weight:600}.tab-active{color:#3498db!important;border-bottom:2px solid #3498db;padding-bottom:4px}.tab-inactive{color:#7f8c8d!important;padding-bottom:4px}.tab-inactive:hover{color:#34495e!important}.close-btn{background:none;border:none;font-size:1.5rem;color:#95a5a6;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background-color:#eecaca;color:#e74c3c}.modal-body{padding:1rem 1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:0;padding:.75rem;border-top:1px solid #e0e0e0;background-color:#fafafa;border-radius:0 0 12px 12px}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.9rem}.data-table th{text-align:left;padding:12px;background-color:#f8f9fa;color:#7f8c8d;font-weight:600;border-bottom:1px solid #eee}.data-table td{padding:12px;border-bottom:1px solid #f0f0f0;color:#34495e}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:#fcfcfc}.role-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.role-badge.superadmin{background-color:#e8f4fd;color:#3498db}.role-badge.admin{background-color:#f0f3f4;color:#7f8c8d}.add-btn{background-color:#2ecc71;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s;font-weight:500}.add-btn:hover{background-color:#27ae60;transform:translateY(-1px)}.action-btn{border:none;background:none;cursor:pointer;font-size:.85rem;padding:4px 8px;border-radius:4px;margin-right:4px;transition:all .2s}.action-btn.edit{color:#3498db;background-color:#ebf5fb}.action-btn.edit:hover{background-color:#d6eaf8}.action-btn.enable{color:#27ae60;background-color:#e8f8f5}.action-btn.enable:hover{background-color:#d4efdf}.action-btn.delete{color:#e74c3c;background-color:#fdedec}.action-btn.delete:hover{background-color:#fadbd8}.status-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.7rem;margin-left:6px}.status-badge.inactive{background-color:#ffebee;color:#c62828;border:1px solid #ffcdd2}.form-card{background-color:#fcfcfc;border:1px solid #eee;border-radius:8px;padding:1.25rem}.form-card h4{margin:0 0 1.25rem;color:#2c3e50;font-size:1.1rem}.form-group{margin-bottom:.5rem}.form-group label{display:block;margin-bottom:.2rem;color:#34495e;font-weight:500;font-size:.8rem}.form-group .hint{font-size:.8rem;color:#95a5a6;font-weight:400}.form-group input,.form-group select{width:100%;padding:.4rem .5rem;border:1px solid #e0e0e0;border-radius:4px;font-size:.85rem;transition:all .2s;box-sizing:border-box;background-color:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-actions{display:flex;gap:10px;margin-top:1.5rem}.delete-btn{background-color:#ffebee;color:#c62828;border:1px solid #ffcdd2;padding:.5rem 1rem;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.85rem}.delete-btn:hover{background-color:#ffcdd2;color:#b71c1c}.save-btn{flex:1;background-color:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.85rem;max-width:120px}.save-btn:hover{background-color:#2980b9}.cancel-btn{flex:1;background-color:#fff;color:#7f8c8d;border:1px solid #e0e0e0;padding:.5rem 1rem;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.85rem;max-width:80px;margin-right:10px}.cancel-btn:hover{background-color:#f5f5f5;color:#34495e}.mono-text{font-family:SF Mono,Roboto Mono,Courier New,monospace;font-size:.85rem;color:#666}.loading-state{text-align:center;padding:2rem;color:#95a5a6;font-style:italic}.modal-flex-container{display:flex;gap:20px}.modal-list-section{flex:1;border-right:1px solid #eee;padding-right:20px}.modal-form-section{width:300px}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.modal-flex-container{flex-direction:column;gap:1.5rem}.modal-list-section{border-right:none;padding-right:0;border-bottom:1px solid #eee;padding-bottom:1.5rem}.modal-form-section{width:100%}.modal-header,.modal-body{padding:1rem}.data-table th,.data-table td{padding:8px;font-size:.8rem}}.site-management-modal{display:flex;flex-direction:column;height:100%}.smm-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;padding:10px;background-color:#f9f9f9;border-radius:4px}.smm-select,.smm-input{padding:8px;border-radius:4px;border:1px solid #ddd;font-size:14px}.smm-input{flex:1;min-width:200px}.smm-batch-toolbar{margin-bottom:15px;padding:10px;background-color:#e8f4fd;border:1px solid #b6d4fe;border-radius:4px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.smm-batch-btn{padding:6px 12px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:opacity .2s}.smm-batch-btn:hover{opacity:.9}.smm-table-container{overflow-x:auto;flex:1}.smm-table{width:100%;border-collapse:collapse;font-size:14px}.smm-th{padding:12px 10px;text-align:left;background-color:#f0f0f0;border-bottom:2px solid #ddd;font-weight:600;white-space:nowrap}.smm-td{padding:12px 10px;border-bottom:1px solid #eee;vertical-align:top}.smm-tr-disabled{background-color:#f9f9f9;color:#999}.smm-tr-rejected{background-color:#fff5f5}.smm-status-select{padding:4px;border-radius:4px;border:1px solid #ddd;font-size:12px;cursor:pointer}.smm-active-toggle{margin-top:5px;display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.smm-action-btn{padding:6px 12px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;margin-right:5px;white-space:nowrap}.smm-btn-edit{background-color:#3498db}.smm-btn-share{background-color:#9b59b6}.smm-btn-delete{background-color:#e74c3c}.smm-rating-cell:hover{background-color:#f0f0f0}@media (max-width: 768px){.smm-table,.smm-thead,.smm-tbody,.smm-th,.smm-td,.smm-tr{display:block}.smm-thead{display:none}.smm-tr{margin-bottom:15px;border:1px solid #ddd;border-radius:8px;padding:15px;background-color:#fff;box-shadow:0 2px 4px #0000000d}.smm-td{border:none;position:relative;padding:5px 0;text-align:left;display:flex;justify-content:space-between;align-items:flex-start}.smm-td-address{font-size:16px;font-weight:700;color:#333;margin-bottom:5px;display:block}.smm-td-meta{font-size:12px;color:#666;display:block}.smm-td-actions{display:flex;justify-content:center;align-items:center;gap:5px}.smm-filters{flex-direction:column;gap:10px}.smm-select,.smm-input{width:100%;min-width:0}}.customer-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.customer-modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;width:90%;max-height:90vh;display:flex;flex-direction:column}.customer-modal-header{padding:16px 20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.customer-modal-title{margin:0;font-size:18px;font-weight:600}.customer-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999}.customer-modal-body{padding:20px;overflow-y:auto;flex:1}.customer-form{margin-bottom:20px;padding:15px;background-color:#f9f9f9;border-radius:6px;display:flex;gap:10px;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:5px;flex:1}.form-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.btn-primary{padding:8px 16px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.customer-table{width:100%;border-collapse:collapse}.customer-table th,.customer-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.customer-table th{background-color:#f5f5f5;font-weight:600}.btn-edit{padding:4px 8px;background-color:#f39c12;color:#fff;border:none;border-radius:4px;cursor:pointer;margin-right:5px}.btn-delete{padding:4px 8px;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer}.empty-state{text-align:center;padding:30px;color:#999}.lesson-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.lesson-modal-content{background:white;border-radius:8px;width:95%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.lesson-modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee}.lesson-modal-title{margin:0;font-size:18px;color:#333}.lesson-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;line-height:1}.lesson-modal-close:hover{color:#333}.lesson-modal-body{padding:20px;overflow-y:auto;flex:1}.lesson-container{min-height:400px}.lesson-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.lesson-list-title{margin:0;font-size:16px;color:#333}.lesson-filters{display:flex;gap:12px;margin-bottom:15px;flex-wrap:wrap}.lesson-search-input{flex:1;min-width:200px;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s}.lesson-search-input:focus{outline:none;border-color:#3498db}.lesson-status-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:white;cursor:pointer;min-width:120px}.lesson-status-select:focus{outline:none;border-color:#3498db}.lesson-item-status{color:#e74c3c;font-weight:500}.lesson-btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.lesson-btn-primary{background-color:#3498db;color:#fff}.lesson-btn-primary:hover{background-color:#2980b9}.lesson-btn-secondary{background-color:#ecf0f1;color:#333}.lesson-btn-secondary:hover{background-color:#ddd}.lesson-loading,.lesson-empty{text-align:center;padding:40px;color:#999}.lesson-list{display:flex;flex-direction:column;gap:12px}.lesson-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f9f9f9;border-radius:8px;border:1px solid #eee;transition:all .2s}.lesson-item:hover{background:#f5f5f5;border-color:#ddd}.lesson-item-disabled{opacity:.6}.lesson-item-content{flex:1;cursor:pointer}.lesson-item-title{margin:0 0 8px;font-size:16px;color:#333}.lesson-item-meta{margin:0 0 8px;font-size:13px;color:#666;line-height:1.4}.lesson-item-info{display:flex;gap:15px;font-size:12px;color:#999}.lesson-item-media{color:#3498db}.lesson-item-actions{display:flex;gap:8px;margin-left:15px}.lesson-item-btn{padding:4px 10px;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.lesson-item-btn-edit{background-color:#3498db;color:#fff}.lesson-item-btn-edit:hover{background-color:#2980b9}.lesson-item-btn-delete{background-color:#e74c3c;color:#fff}.lesson-item-btn-delete:hover{background-color:#c0392b}.lesson-item-btn-disable{background-color:#f39c12;color:#fff}.lesson-item-btn-disable:hover{background-color:#e67e22}.lesson-item-btn-enable{background-color:#27ae60;color:#fff}.lesson-item-btn-enable:hover{background-color:#219a52}.lesson-viewer{padding:10px 0}.lesson-viewer-title{margin:0 0 20px;font-size:20px;color:#333;padding-bottom:15px;border-bottom:2px solid #3498db}.lesson-viewer-content{margin-bottom:20px}.lesson-content-text{font-size:14px;line-height:1.8;color:#555;white-space:pre-wrap}.lesson-viewer-section{margin-bottom:25px}.lesson-section-title{margin:0 0 12px;font-size:16px;color:#333;font-weight:600}.lesson-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.lesson-image-item{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:transform .2s}.lesson-image-item:hover{transform:scale(1.02)}.lesson-image-item img{width:100%;height:100%;object-fit:cover}.lesson-videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px}.lesson-video-item{border-radius:8px;overflow:hidden;background:#000;box-shadow:0 2px 8px #0000001a}.lesson-video-item video{width:100%;display:block}.lesson-viewer-footer{display:flex;justify-content:space-between;align-items:center;margin-top:25px;padding-top:15px;border-top:1px solid #eee}.lesson-meta{font-size:13px;color:#999}.lesson-actions{display:flex;gap:10px}.lesson-form{display:flex;flex-direction:column;gap:20px}.lesson-form-group{display:flex;flex-direction:column;gap:8px}.lesson-form-label{font-weight:600;color:#333;font-size:14px}.lesson-form-input{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s}.lesson-form-input:focus{outline:none;border-color:#3498db}.lesson-form-textarea{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;resize:vertical;min-height:120px;font-family:inherit;line-height:1.5}.lesson-form-textarea:focus{outline:none;border-color:#3498db}.lesson-form-row{display:flex;gap:20px}.lesson-form-row .lesson-form-group{flex:1}.lesson-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.lesson-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.lesson-media-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px}.lesson-media-preview-item{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;background:#f5f5f5}.lesson-media-preview-item img,.lesson-media-preview-item video{width:100%;height:100%;object-fit:cover}.lesson-video-preview-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.lesson-video-preview-item{aspect-ratio:16/9;background:#000}.lesson-media-remove-btn{position:absolute;top:-5px;right:-5px;width:22px;height:22px;border-radius:50%;background:#e74c3c;color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:10}.lesson-media-remove-btn:hover{background:#c0392b}.lesson-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px;padding-top:15px;border-top:1px solid #eee}.image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.image-preview-content{position:relative;max-width:90%;max-height:90%}.image-preview-content img{max-width:100%;max-height:90vh;object-fit:contain}.preview-close-btn{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:30px;cursor:pointer;padding:5px}.preview-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.2);border:none;color:#fff;font-size:24px;padding:15px 10px;cursor:pointer;border-radius:4px}.preview-nav-btn:hover{background:rgba(255,255,255,.3)}.preview-nav-btn.prev{left:-50px}.preview-nav-btn.next{right:-50px}.preview-counter{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);color:#fff;font-size:14px}@media (max-width: 768px){.lesson-modal-content{width:100%;max-height:100vh;border-radius:0}.lesson-filters{flex-direction:column}.lesson-search-input{min-width:100%}.lesson-status-select{width:100%}.lesson-item{flex-direction:column;align-items:flex-start}.lesson-item-actions{margin-left:0;margin-top:10px;width:100%;justify-content:flex-end}.lesson-form-row{flex-direction:column;gap:15px}.lesson-images-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.lesson-videos-grid{grid-template-columns:1fr}.preview-nav-btn.prev{left:10px}.preview-nav-btn.next{right:10px}}.site-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:2000;display:flex;justify-content:center;align-items:center;padding:10px}.image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;z-index:3000;display:flex;justify-content:center;align-items:center}.image-preview-content{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.image-preview-content img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.preview-close-btn{position:absolute;top:20px;right:20px;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:24px;cursor:pointer;z-index:3001;display:flex;justify-content:center;align-items:center}.preview-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:24px;cursor:pointer;z-index:3001;display:flex;justify-content:center;align-items:center}.preview-nav-btn.prev{left:20px}.preview-nav-btn.next{right:20px}.preview-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);color:#fff;background:rgba(0,0,0,.5);padding:5px 15px;border-radius:20px;font-size:14px}@media (max-width: 768px){.preview-nav-btn{display:none}}.site-modal-content{background-color:#fff;padding:20px;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column}.site-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #eee;padding-bottom:10px}.site-modal-title{margin:0;font-size:18px;font-weight:600}.site-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0 5px}.site-form{display:flex;flex-direction:column;gap:15px}.form-group{margin-bottom:0}.site-form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}@media (max-width: 600px){.site-form-row{grid-template-columns:1fr;gap:10px}}.form-label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:#333}.form-sublabel{display:block;margin-bottom:4px;font-size:12px;color:#666}.form-input,.form-select,.form-textarea{width:100%;padding:10px;border-radius:4px;border:1px solid #ddd;box-sizing:border-box;font-size:14px;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3498db;outline:none}.form-textarea{min-height:80px;resize:vertical}.input-with-btn{display:flex;gap:10px}.btn-primary{padding:10px 20px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;white-space:nowrap;transition:background-color .2s}.btn-primary:hover{background-color:#2980b9}.btn-primary:disabled{background-color:#95a5a6;cursor:not-allowed}.btn-secondary{padding:10px 20px;background-color:#fff;color:#666;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s}.btn-secondary:hover{background-color:#f5f5f5;border-color:#ccc}.tag-container{display:flex;flex-wrap:wrap;gap:8px}.tag-btn{padding:6px 12px;border-radius:20px;border:1px solid #e0e0e0;background-color:#fff;color:#666;cursor:pointer;font-size:13px;transition:all .2s}.tag-btn:hover{background-color:#f8f9fa;border-color:#ccc}.tag-btn.active{background-color:#3498db;color:#fff;border-color:#3498db;box-shadow:0 2px 4px #3498db4d}.admin-section{padding:15px;background-color:#f8f9fa;border-radius:8px;border:1px solid #eee;margin-top:10px}.admin-title{margin:0 0 15px;font-size:14px;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;-webkit-user-select:none;user-select:none}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:15px;border-top:1px solid #eee}.error-message{color:#e74c3c;background-color:#fde8e7;padding:10px;border-radius:4px;font-size:14px;border:1px solid #fadbd8}.preview-section{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.preview-section:last-child{border-bottom:none;padding-bottom:0}.preview-row{display:flex;align-items:baseline;margin-bottom:12px}.preview-label{font-weight:600;color:#666;min-width:80px;flex-shrink:0}.preview-value{color:#333;flex:1;word-break:break-word}.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:20px;background-color:#f9fafb;padding:15px;border-radius:8px}.preview-grid-item{display:flex;flex-direction:column;gap:4px}.preview-grid-label{font-size:12px;color:#888;font-weight:500}.preview-grid-value{font-size:15px;color:#333;font-weight:600}@media (max-width: 600px){.preview-grid{grid-template-columns:1fr 1fr;gap:12px}}.preview-tag{display:inline-block;background:#e3f2fd;color:#1976d2;padding:4px 10px;border-radius:12px;font-size:12px;margin-right:8px;margin-bottom:8px}.official-reason{background:#fff8e1;padding:15px;border-radius:6px;border-left:4px solid #ffb300;margin-top:15px;margin-bottom:20px}.official-reason-title{font-weight:700;color:#f57c00;margin-bottom:8px;display:block}.media-grid-video{margin-top:10px;display:flex;flex-direction:column;gap:15px}.media-grid-video>div{width:100%}.add-site-fab{position:fixed;bottom:140px;right:20px;width:50px;height:50px;background-color:#3498db;color:#fff;border-radius:50%;display:none;justify-content:center;align-items:center;font-size:30px;line-height:1;box-shadow:0 4px 10px #0000004d;cursor:pointer;z-index:1000;transition:transform .2s,background-color .2s;-webkit-user-select:none;user-select:none;padding-bottom:4px}.add-site-fab:hover{background-color:#2980b9;transform:scale(1.05)}.add-site-fab:active{transform:scale(.95)}@media (max-width: 768px){.add-site-fab{display:flex;right:10px;bottom:20px}}.share-page{position:relative;width:100vw;height:100vh;overflow:hidden}.share-header{position:absolute;top:20px;left:50%;transform:translate(-50%);background-color:#fff9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:20px;padding:10px 24px;box-shadow:0 4px 12px #0000001a;z-index:1000;display:flex;align-items:center;justify-content:center;white-space:nowrap}.share-header h1{margin:0;font-size:18px;color:#333;font-weight:600}.map-container{width:100%;height:100%}.zoom-controls{position:absolute;right:20px;bottom:40px;display:flex;flex-direction:column;gap:5px;z-index:1000}.zoom-controls button{width:36px;height:36px;background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:20px;cursor:pointer;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center}.share-error-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#f5f5f5}.share-error-box{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 4px 12px #0000001a;text-align:center}.share-error-box h2{color:#e74c3c;margin-top:0}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#fffc;display:flex;justify-content:center;align-items:center;z-index:2000;font-size:18px;color:#333}.share-list-container{position:absolute;top:80px;left:20px;width:300px;background-color:#fffffff2;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;display:flex;flex-direction:column;max-height:calc(100vh - 120px);transition:all .3s ease}.share-list-container.collapsed{width:auto;background-color:transparent;box-shadow:none}.share-list-container.collapsed .share-list-header{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026}.share-list-container.collapsed h3{display:none}.share-list-header{padding:12px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background-color:#fff;border-radius:8px 8px 0 0}.share-list-header h3{margin:0;font-size:16px;color:#333}.toggle-btn{background:none;border:none;color:#3498db;cursor:pointer;font-size:14px;padding:0}.share-list-content{overflow-y:auto;flex:1;background-color:#fff;border-radius:0 0 8px 8px}.empty-state{padding:20px;text-align:center;color:#999;font-size:14px}.share-list-item{padding:12px 16px;border-bottom:1px solid #f5f5f5;cursor:pointer;display:flex;align-items:center;gap:12px;transition:background-color .2s}.share-list-item:hover{background-color:#f0f9ff}.share-list-item.active{background-color:#e1f5fe}.rating-badge{color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.site-info{flex:1;overflow:hidden}.site-address{font-size:14px;color:#333;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.site-meta{font-size:12px;color:#666}@media (max-width: 768px){.share-header h1{font-size:14px}.share-list-container{top:auto;bottom:20px;left:10px;right:10px;width:auto;max-height:40vh}.share-list-container.collapsed{width:auto;left:10px;bottom:20px}.zoom-controls{bottom:auto;top:80px}}
