@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--font-primary:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-heading:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--primary:#224c92;--primary-dark:#16315f;--primary-light:#eaf0f9;--primary-gradient:linear-gradient(135deg, #2a5aa8 0%, #16315f 100%);--accent-gold:#c9a24d;--accent-gold-dark:#a8842f;--accent-gold-gradient:linear-gradient(135deg, #ddbe6e 0%, #c9a24d 100%);--accent-hot:#e53e3e;--accent-green:#38a169;--accent-purple:#805ad5;--bg-body:#f7f8fc;--bg-white:#fff;--bg-card:#fff;--bg-subtle:#f0f4fa;--bg-dark:#122a52;--bg-dark-2:#0d1f3d;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#a0aec0;--text-white:#fff;--text-link:#224c92;--border-light:#e2e8f0;--border-medium:#cbd5e0;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 30px #0000001f;--shadow-xl:0 20px 60px #00000026;--shadow-glow:0 0 30px #224c9226;--header-height:72px;--container-max:1280px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:var(--text-primary);background:var(--bg-body);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.6}a{color:inherit;transition:color var(--transition-fast);text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul,ol{list-style:none}.container{max-width:var(--container-max);margin:0 auto;padding:0 24px}.section{padding:80px 0}.section-title{font-family:var(--font-heading);color:var(--primary);letter-spacing:-.01em;margin-bottom:8px;font-size:34px;font-weight:800}.section-subtitle{color:var(--text-secondary);margin-bottom:40px;font-size:16px}.badge{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.badge-hot{color:#fff;background:linear-gradient(135deg,#e53e3e,#c53030)}.badge-new{color:#fff;background:linear-gradient(135deg,#38a169,#2f855a)}.badge-exclusive{color:#fff;background:linear-gradient(135deg,#805ad5,#6b46c1)}.badge-promo{color:#fff;background:linear-gradient(135deg,#f6ad55,#dd6b20)}.btn{border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(#ffffff1a 0%,#0000 100%);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #0058dd59}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #224c9273}.btn-gold{background:var(--accent-gold-gradient);color:#3a2e08;box-shadow:0 4px 14px #c9a24d66}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 20px #c9a24d80}.btn-outline{border:2px solid var(--primary);color:var(--primary);background:0 0}.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.btn-white{color:var(--primary);box-shadow:var(--shadow-md);background:#fff}.btn-white:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-sm{padding:8px 16px;font-size:13px}.btn-lg{padding:16px 32px;font-size:16px}.header{height:var(--header-height);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);z-index:1000;transition:all var(--transition-base);background:#fffffff2;position:fixed;top:0;left:0;right:0}.header.scrolled{box-shadow:var(--shadow-md)}.header-inner{justify-content:space-between;align-items:center;gap:32px;height:100%;display:flex}.header-logo{color:var(--primary);flex-shrink:0;align-items:center;gap:10px;font-size:24px;font-weight:800;display:flex}.brand-logo-img{width:auto;height:42px;display:block}.header-logo .logo-icon{background:var(--primary-gradient);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:900;display:flex}.header-search{flex:1;max-width:400px;position:relative}.header-search input{border:2px solid var(--border-light);border-radius:var(--radius-full);background:var(--bg-subtle);width:100%;transition:all var(--transition-base);outline:none;padding:10px 16px 10px 42px;font-family:inherit;font-size:14px}.header-search input:focus{border-color:var(--primary);box-shadow:var(--shadow-glow);background:#fff}.header-search .search-icon{color:var(--text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.header-nav{align-items:center;gap:4px;display:flex}.header-nav a{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:8px 16px;font-size:14px;font-weight:500;position:relative}.header-nav a:hover,.header-nav a.active{color:var(--primary);background:var(--primary-light)}.header-nav a.active:after{content:"";background:var(--primary);border-radius:1px;height:2px;position:absolute;bottom:-1px;left:16px;right:16px}.header-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.mobile-menu-btn{color:var(--text-primary);padding:8px;display:none}.mobile-nav{top:var(--header-height);z-index:999;background:#fff;padding:24px;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.mobile-nav.open{animation:.25s slideDown;display:block}.mobile-nav a{color:var(--text-primary);border-bottom:1px solid var(--border-light);padding:16px 0;font-size:16px;font-weight:500;display:block}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.mobile-nav.open,.page-enter,.page-transition,.fade-in,[class*=enter]{opacity:1!important;animation:none!important;transform:none!important}}.ms-brand{flex-direction:column;flex-shrink:0;justify-content:center;align-items:flex-start;gap:3px;min-width:0;display:flex}.ms-brand-logo{filter:drop-shadow(0 1px 2px #2563eb33);width:auto;height:46px;display:block}.ms-brand-mark{background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:11px;flex:none;place-items:center;width:38px;height:38px;display:grid;box-shadow:0 6px 14px #2563eb52}.ms-brand-text{flex-direction:column;min-width:0;line-height:1.1;display:flex}.ms-brand-name{color:#1d4ed8;letter-spacing:-.4px;font-size:20px;font-weight:800}.ms-brand-sub{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.ms-topnav{align-items:center;gap:2px;display:flex}.ms-topnav-item{color:#334155;white-space:nowrap;border-radius:9px;align-items:center;gap:6px;padding:8px 14px;font-size:16px;font-weight:700;transition:all .16s;display:inline-flex}.ms-topnav-item.active{color:#1d4ed8;cursor:pointer;background:#eff4ff}.ms-topnav-item.active:hover{background:#e3ecff}.ms-topnav-item.soon{color:#9aa6b8;cursor:not-allowed}.ms-topnav-item.soon i{text-transform:uppercase;letter-spacing:.3px;color:#94a3b8;background:#f1f5f9;border:1px solid #e6ebf3;border-radius:10px;padding:2px 6px;font-size:8px;font-style:normal;font-weight:700}.ms-topbar-actions{gap:8px}.ms-icon-btn{border:1px solid var(--border-light);width:40px;height:40px;color:var(--text-primary);cursor:pointer;background:#fff;border-radius:11px;place-items:center;transition:all .18s;display:grid;position:relative}.ms-icon-btn:hover{background:var(--primary-light);color:#1d4ed8;border-color:#93c5fd}.ms-dot{background:#ef4444;border:2px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:9px;right:10px}.ms-account{border:1px solid var(--border-light);cursor:pointer;background:#fff;border-radius:999px;align-items:center;gap:10px;padding:5px 14px 5px 6px;transition:all .18s;display:flex}.ms-account:hover{background:var(--primary-light);border-color:#93c5fd}.ms-account-av{color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;flex:none;place-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:grid}.ms-account-name{color:var(--text-primary);white-space:nowrap;font-size:14px;font-weight:600}.mobile-nav-soon{color:var(--text-muted);border-bottom:1px solid var(--border-light);cursor:not-allowed;padding:16px 0;font-size:16px;font-weight:500;display:block}.mobile-nav-soon i{text-transform:uppercase;color:#94a3b8;background:#f1f5f9;border-radius:10px;margin-left:6px;padding:2px 7px;font-size:10px;font-style:normal;font-weight:700}@media (width<=1024px){.ms-topnav,.ms-brand-sub{display:none}.mobile-menu-btn{display:flex}}@media (width<=680px){.ms-account-name{display:none}}.hero{height:600px;margin-top:var(--header-height);position:relative;overflow:hidden}.hero-slide{background-position:50%;background-size:cover;height:600px;position:relative}.hero-slide:before{content:"";background:linear-gradient(135deg,#0a1628d9 0%,#0058dd4d 100%);position:absolute;inset:0}.hero-content{z-index:2;height:100%;max-width:var(--container-max);flex-direction:column;justify-content:center;margin:0 auto;padding:0 24px;display:flex;position:relative}.hero-tag{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-full);color:#fff;background:#ffffff26;border:1px solid #fff3;align-items:center;gap:8px;width:fit-content;margin-bottom:24px;padding:8px 16px;font-size:13px;font-weight:500;animation:.6s .2s both fadeInUp;display:inline-flex}.hero h1{font-family:var(--font-heading);color:#fff;letter-spacing:-.01em;margin-bottom:16px;font-size:56px;font-weight:800;line-height:1.15;animation:.6s .3s both fadeInUp}.hero h1 span{background:var(--accent-gold-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero p{color:#fffc;max-width:520px;margin-bottom:32px;font-size:18px;animation:.6s .4s both fadeInUp}.hero-buttons{gap:16px;animation:.6s .5s both fadeInUp;display:flex}.hero-stats{gap:48px;margin-top:48px;animation:.6s .6s both fadeInUp;display:flex}.hero-stat{text-align:center}.hero-stat .number{color:#fff;font-size:36px;font-weight:800}.hero-stat .label{color:#fff9;margin-top:4px;font-size:13px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.spinner{color:var(--primary);animation:1s linear infinite spin}.osd-pin{background:var(--pc,#6b7280);cursor:pointer;border:2px solid #fff;border-radius:50%;width:12px;height:12px;transition:transform .12s;box-shadow:0 0 0 1.5px #00000059}.osd-pin:hover{z-index:5;transform:scale(1.7)}.project-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.project-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-slow);border:1px solid var(--border-light);position:relative;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-xl);border-color:#0000;transform:translateY(-8px)}.project-card-image{height:220px;position:relative;overflow:hidden}.project-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.project-card:hover .project-card-image img{transform:scale(1.08)}.project-card-badges{z-index:2;gap:6px;display:flex;position:absolute;top:12px;left:12px}.project-card-type{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);color:#fff;background:#0009;padding:4px 10px;font-size:11px;font-weight:500;position:absolute;bottom:12px;right:12px}.project-card-body{padding:20px}.project-card-body h3{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:700;line-height:1.3}.project-card-body h3:hover{color:var(--primary)}.project-card-location{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:16px;font-size:13px;display:flex}.project-card-meta{border-top:1px solid var(--border-light);grid-template-columns:1fr 1fr;gap:8px;padding-top:16px;display:grid}.project-card-meta-item{color:var(--text-muted);font-size:12px}.project-card-meta-item strong{color:var(--text-primary);font-size:14px;font-weight:600;display:block}.project-card-price{border-top:1px solid var(--border-light);align-items:center;gap:4px;margin-top:16px;padding-top:16px;display:flex}.project-card-price .price-value{color:var(--accent-hot);font-size:20px;font-weight:800}.project-card-price .price-unit{color:var(--text-muted);font-size:13px}.unit-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border-light);background:#fff;overflow-x:auto}.unit-table{border-collapse:collapse;width:100%;font-size:13px}.unit-table thead{background:var(--bg-dark);color:#fff}.unit-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:14px 16px;font-size:12px;font-weight:600}.unit-table td{border-bottom:1px solid var(--border-light);white-space:nowrap;padding:12px 16px}.unit-table tbody tr{transition:background var(--transition-fast)}.unit-table tbody tr:hover{background:var(--primary-light)}.unit-table .unit-code{color:var(--primary);cursor:pointer;font-weight:700}.unit-table .unit-code:hover{text-decoration:underline}.unit-table .unit-price{color:var(--accent-hot);font-weight:700}.unit-table-wrapper.sticky-head{max-height:calc(100vh - 260px);overflow:auto}.unit-table-wrapper.sticky-head thead th{z-index:2;background:var(--bg-dark);position:sticky;top:0}.admin-pager{color:var(--text-secondary);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;font-size:13px;display:flex}.admin-pager-size{align-items:center;gap:7px;display:flex}.admin-pager-size select{border:1px solid var(--border-light);cursor:pointer;background:#fff;border-radius:8px;height:34px;padding:0 8px;font-family:inherit;font-size:13.5px;font-weight:600}.admin-pager-nav{align-items:center;gap:4px;display:flex}.admin-pg-btn{border:1px solid var(--border-light);color:#334155;cursor:pointer;background:#fff;border-radius:8px;min-width:34px;height:34px;padding:0 8px;font-family:inherit;font-size:13.5px;font-weight:600}.admin-pg-btn:hover:not(:disabled){border-color:var(--primary)}.admin-pg-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.admin-pg-btn:disabled{opacity:.45;cursor:not-allowed}.admin-pg-ellipsis{color:var(--text-muted);padding:0 4px}.unit-status{border-radius:var(--radius-full);padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.unit-status.available{color:#22543d;background:#c6f6d5}.unit-status.hold{color:#744210;background:#fefcbf}.unit-status.deposit{color:#742a2a;background:#fed7d7}.unit-status.sold{color:#fff;background:#ef4444}.filter-bar{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);background:#fff;margin-bottom:24px;padding:24px}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.filter-group{flex:1;min-width:180px}.filter-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.filter-group select,.filter-group input{border:2px solid var(--border-light);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition-fast);background:#fff;outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary)}.region-tabs{gap:8px;margin-bottom:24px;display:flex}.region-tab{border-radius:var(--radius-full);border:2px solid var(--border-light);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;background:#fff;padding:10px 24px;font-size:14px;font-weight:600}.region-tab:hover{border-color:var(--primary);color:var(--primary)}.region-tab.active{background:var(--primary-gradient);color:#fff;border-color:#0000;box-shadow:0 4px 14px #0058dd40}.tabs{border-bottom:2px solid var(--border-light);flex-wrap:wrap;gap:2px;margin-bottom:32px;display:flex}.tabs::-webkit-scrollbar{display:none}.tab{color:var(--text-secondary);white-space:nowrap;transition:all var(--transition-fast);cursor:pointer;border-bottom:3px solid #0000;flex-shrink:0;align-items:center;gap:8px;margin-bottom:-2px;padding:14px 12px;font-size:14px;font-weight:600;display:flex}.tab:hover{color:var(--primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.pd-tabs{border-bottom:none;gap:8px;padding:14px 0}.pd-tabs .tab{background:#fff;border:1.5px solid #7cc4ff;border-radius:999px;align-items:center;gap:6px;margin-bottom:0;padding:9px 16px;display:inline-flex}.pd-tabs .tab:hover{border-color:var(--primary)}.pd-tabs .tab.active{border-color:var(--primary);color:var(--primary);background:#eaf4ff}.footer{background:linear-gradient(180deg, var(--bg-dark) 0%, var(--bg-dark-2) 100%);color:#ffffffb8;border-top:3px solid var(--accent-gold);padding:64px 0 32px}.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;display:grid}.footer-brand{align-items:center;gap:10px;margin-bottom:16px;display:flex}.footer-logo-img{width:auto;height:80px;display:block}.footer h4{color:#fff;margin-bottom:20px;padding-bottom:8px;font-size:16px;font-weight:700;position:relative}.footer h4:after{content:"";background:var(--accent-gold);width:36px;height:2px;position:absolute;bottom:0;left:0}.footer ul li{margin-bottom:10px}.footer ul li a:hover{color:var(--accent-gold)}.footer-bottom{border-top:1px solid #c9a24d40;justify-content:space-between;align-items:center;padding-top:32px;font-size:13px;display:flex}.page-enter{animation:.4s both pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.scroll-top{background:var(--primary-gradient);color:#fff;border-radius:var(--radius-full);width:48px;height:48px;box-shadow:var(--shadow-lg);z-index:100;opacity:0;transition:all var(--transition-base);cursor:pointer;justify-content:center;align-items:center;display:flex;position:fixed;bottom:24px;right:24px;transform:translateY(20px)}.scroll-top.visible{opacity:1;transform:translateY(0)}.scroll-top:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.unit-card{border-radius:var(--radius-lg);border:1px solid var(--border-light);transition:all var(--transition-slow);background:#fff;padding:20px;position:relative;overflow:hidden}.unit-card:before{content:"";background:var(--primary-gradient);height:4px;transition:transform var(--transition-base);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.unit-card:hover{box-shadow:var(--shadow-lg);border-color:#0000;transform:translateY(-4px)}.unit-card:hover:before{transform:scaleX(1)}.unit-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.unit-card-code{color:var(--primary);font-size:18px;font-weight:800}.unit-card-body{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.unit-card-field{color:var(--text-muted);font-size:12px}.unit-card-field strong{color:var(--text-primary);font-size:14px;font-weight:600;display:block}.unit-card-price{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-top:16px;display:flex}.unit-card-price .price{color:var(--accent-hot);font-size:22px;font-weight:800}.unit-card-price .price small{color:var(--text-muted);font-size:13px;font-weight:400}.detail-hero{height:450px;margin-top:var(--header-height);background-position:50%;background-size:cover;position:relative}.detail-hero:before{content:"";background:linear-gradient(#0000004d 0%,#000000b3 100%);position:absolute;inset:0}.detail-hero-content{z-index:2;flex-direction:column;justify-content:flex-end;height:100%;padding-bottom:48px;display:flex;position:relative}.detail-hero-content h1{font-family:var(--font-heading);color:#fff;margin-bottom:12px;font-size:44px;font-weight:800}.detail-hero-content .location{color:#fffc;align-items:center;gap:8px;font-size:16px;display:flex}.timeline{padding-left:32px;position:relative}.timeline:before{content:"";background:var(--border-light);width:2px;position:absolute;top:0;bottom:0;left:11px}.timeline-item{padding-bottom:32px;padding-left:24px;position:relative}.timeline-item:before{content:"";border:3px solid var(--border-medium);z-index:1;background:#fff;border-radius:50%;width:14px;height:14px;position:absolute;top:4px;left:-26px}.timeline-item.completed:before{background:var(--accent-green);border-color:var(--accent-green)}.timeline-item.in-progress:before{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 4px #0058dd33}.timeline-item .date{color:var(--primary);text-transform:uppercase;margin-bottom:4px;font-size:12px;font-weight:700}.timeline-item .title{color:var(--text-primary);font-size:15px;font-weight:600}.auth-page{background:linear-gradient(135deg,#0a1628 0%,#1a365d 50%,#0058dd 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";background:radial-gradient(circle,#0058dd4d,#0000);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);z-index:2;background:#fffffff2;padding:48px;position:relative}.auth-card h2{color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:800}.auth-card .subtitle{color:var(--text-secondary);margin-bottom:32px}.auth-notice,.auth-error,.auth-success{border-radius:var(--radius-md);align-items:flex-start;gap:8px;margin-bottom:20px;padding:12px 14px;font-size:13px;line-height:1.5;display:flex}.auth-notice{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.auth-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.auth-success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.auth-notice code{background:#0000000f;border-radius:4px;padding:1px 5px;font-size:12px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input{border:2px solid var(--border-light);border-radius:var(--radius-md);width:100%;transition:all var(--transition-fast);outline:none;padding:12px 16px;font-family:inherit;font-size:15px}.form-group input:focus{border-color:var(--primary);box-shadow:var(--shadow-glow)}.loading-spinner{justify-content:center;padding:60px 0;display:flex}.spinner{border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.empty-state{text-align:center;color:var(--text-muted);padding:60px 24px}.empty-state svg{opacity:.4;margin-bottom:16px}.detail-overview-grid{grid-template-columns:2fr 1fr;gap:32px;display:grid}@media (width<=1024px){.project-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.hero h1{font-size:40px}.hero-stats{gap:32px}}@media (width<=768px){.header-nav{display:none}.mobile-menu-btn{display:flex}.header-actions{display:none}.header-actions.ms-topbar-actions{display:flex}.detail-overview-grid{grid-template-columns:1fr;gap:24px}.hero,.hero-slide{height:500px}.hero h1{font-size:32px}.hero p{font-size:15px}.hero-stats{gap:24px}.hero-stat .number{font-size:28px}.hero-buttons{flex-direction:column}.project-grid{grid-template-columns:1fr}.section{padding:48px 0}.section-title{font-size:24px}.filter-row{flex-direction:column}.filter-group{min-width:100%}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-bottom{text-align:center;flex-direction:column;gap:16px}.region-tabs{scrollbar-width:none;overflow-x:auto}.region-tabs::-webkit-scrollbar{display:none}.detail-hero{height:350px}.detail-hero-content h1{font-size:28px}.tabs{scrollbar-width:none;flex-wrap:nowrap;gap:0;overflow-x:auto}.tab{padding:12px 16px;font-size:13px}.auth-card{padding:32px 24px}.masterplan-container{margin:0 -24px}.masterplan-toolbar{flex-direction:column;gap:8px}.masterplan-toolbar-left{overflow-x:auto}.unit-modal{width:95vw;max-height:90vh}.unit-modal-body{flex-direction:column}.unit-modal-images{max-width:100%}.admin-page-header{flex-wrap:wrap;gap:10px;padding:10px 16px}.admin-page-title{border-left:none;flex-basis:100%;order:3;padding-left:0;font-size:18px}.admin-home-btn{margin-left:auto}.admin-tabs a{padding:12px 14px;font-size:13px}}.masterplan-container{border-radius:var(--radius-lg);border:1px solid var(--border-light);background:#fff;position:relative;overflow:hidden}.masterplan-empty{height:400px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:16px;display:flex}.masterplan-toolbar{background:var(--bg-subtle);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.masterplan-toolbar-left{flex-wrap:nowrap;gap:6px;display:flex}.masterplan-subarea-btn{border-radius:var(--radius-full);border:2px solid var(--border-light);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap;background:#fff;padding:6px 14px;font-size:12px;font-weight:600}.masterplan-subarea-btn:hover{border-color:var(--primary);color:var(--primary)}.masterplan-subarea-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.masterplan-toolbar-right{gap:8px;display:flex}.masterplan-label-toggle{border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-light);transition:all var(--transition-fast);background:#fff;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.masterplan-label-toggle:hover{border-color:var(--primary);color:var(--primary)}.masterplan-map-wrap{position:relative}.masterplan-search{z-index:20;flex-shrink:0;width:240px;position:relative}.masterplan-search-icon{color:var(--text-secondary);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.masterplan-search-input{width:100%;color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:border-color var(--transition-fast);background:#fffffff7;outline:none;padding:8px 30px 8px 33px;font-size:13px}.masterplan-search-input:focus{border-color:var(--primary)}.masterplan-search-clear{color:var(--text-secondary);align-items:center;display:flex;position:absolute;top:50%;right:11px;transform:translateY(-50%)}.masterplan-search-clear:hover{color:var(--primary)}.masterplan-search-list{z-index:30;border:1px solid var(--border-light);border-radius:var(--radius-md);max-height:300px;box-shadow:var(--shadow-lg);background:#fff;position:absolute;top:calc(100% + 5px);left:0;right:0;overflow-y:auto}.masterplan-search-item{cursor:pointer;align-items:center;gap:8px;padding:8px 12px;font-size:12.5px;display:flex}.masterplan-search-item.active,.masterplan-search-item:hover{background:var(--bg-subtle)}.masterplan-search-item .ms-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.masterplan-search-item .ms-code{flex-shrink:0;font-weight:700}.masterplan-search-item .ms-meta{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.masterplan-search-empty{color:var(--text-secondary);padding:11px 12px;font-size:12.5px}.leaflet-container.mp-leaflet{font:inherit;background:#eef2f7;outline:none}.mp-leaflet .leaflet-control-zoom{box-shadow:var(--shadow-md);border:none}.mp-pin{width:0;height:0}.mp-dot{opacity:.6;cursor:pointer;border-radius:50%;width:11px;height:11px;transform:translate(-50%,-50%)}.leaflet-tooltip.mp-tip{color:#fff;white-space:nowrap;background:#1f2937;border:none;border-radius:6px;padding:2px 8px;font-size:12px;font-weight:700;box-shadow:0 2px 6px #00000059}.mp-tip.leaflet-tooltip-top:before{border-top-color:#1f2937}.mp-dot-focus{opacity:1;border:2px solid #fff;width:15px;height:15px;animation:1.3s ease-out infinite mp-dot-pulse;box-shadow:0 0 0 4px #2563eb66,0 2px 6px #0006}@keyframes mp-dot-pulse{0%{box-shadow:0 0 0 3px #2563eb80,0 2px 6px #0006}70%{box-shadow:0 0 0 12px #2563eb00,0 2px 6px #0006}to{box-shadow:0 0 0 3px #2563eb00,0 2px 6px #0006}}.mp-pill{border:2px solid var(--c,#6b7280);white-space:nowrap;cursor:pointer;background:#fff;border-radius:7px;flex-direction:column;align-items:center;min-width:34px;padding:3px 8px;line-height:1.1;transition:transform 80ms;display:flex;position:absolute;bottom:0;left:0;transform:translate(-50%,-7px);box-shadow:0 2px 6px #00000040}.mp-pill:hover{transform:translate(-50%,-9px)scale(1.04)}.mp-pill-code{color:#1f2937;letter-spacing:.2px;font-size:12px;font-weight:800}.mp-pill-price{color:var(--c,#6b7280);margin-top:1px;font-size:10.5px;font-weight:700}.mp-pill-tip{border-left:5px solid #0000;border-right:5px solid #0000;border-top:7px solid var(--c,#6b7280);width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.mp-pill-dot{background:var(--c,#6b7280);border:1.5px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;right:-4px}.mp-pill-focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb59,0 3px 10px #0000004d}.mp-pill-focus .mp-pill-tip{border-top-color:#2563eb}.masterplan-legend{border-bottom:1px solid var(--border-light);z-index:1100;background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:8px 16px;display:flex;position:relative}.masterplan-legend-items{flex-wrap:wrap;gap:4px;display:flex}.legend-item{border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:500;display:flex}.legend-item:hover,.legend-item.active{background:var(--bg-subtle);border-color:var(--border-light)}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.masterplan-zoom-controls{z-index:10;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);border:1px solid var(--border-light);background:#fff;flex-direction:column;gap:4px;display:flex;position:absolute;top:120px;left:16px;overflow:hidden}.masterplan-zoom-controls button{color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;padding:10px;display:flex}.masterplan-zoom-controls button:hover{background:var(--primary-light);color:var(--primary)}.masterplan-zoom-controls button+button{border-top:1px solid var(--border-light)}.masterplan-image-wrapper{cursor:grab;width:100%;min-height:600px;position:relative}.masterplan-image-wrapper:active{cursor:grabbing}.masterplan-image{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:auto;display:block}.masterplan-pin{z-index:5;cursor:pointer;transition:z-index;position:absolute;transform:translate(-50%,-50%)}.masterplan-pin.hovered{z-index:20}.pin-marker{width:24px;height:30px;position:relative}.pin-marker:before{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-top:10px solid var(--pin-color);width:0;height:0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.pin-dot{background:var(--pin-color);width:20px;height:20px;transition:all var(--transition-fast);border:2px solid #fff;border-radius:50%;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000004d}.masterplan-pin:hover .pin-dot,.masterplan-pin.hovered .pin-dot{transform:translate(-50%)scale(1.3);box-shadow:0 4px 16px #0006}.masterplan-pin.sold .pin-dot{opacity:.5}.pin-label{color:#fff;white-space:nowrap;pointer-events:none;background:#000000d9;border-radius:4px;flex-direction:column;align-items:center;padding:2px 6px;font-size:9px;font-weight:600;line-height:1.3;display:flex;position:absolute;top:-8px;left:50%;transform:translate(-50%)translateY(-100%)}.pin-code{font-size:10px}.pin-price{color:#fbbf24;font-size:9px}.pin-tooltip{border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);pointer-events:none;z-index:30;background:#fff;width:240px;animation:.15s tooltipFadeIn;position:absolute;top:-12px;left:28px;overflow:hidden;transform:translateY(-50%)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%)translate(4px)}to{opacity:1;transform:translateY(-50%)translate(0)}}.pin-tooltip-header{background:var(--bg-subtle);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.pin-tooltip-header strong{font-size:14px}.pin-tooltip-status{border-radius:var(--radius-full);color:#fff;padding:2px 8px;font-size:10px;font-weight:600}.pin-tooltip-body{padding:10px 12px}.pin-tooltip-row{color:var(--text-secondary);justify-content:space-between;padding:3px 0;font-size:12px;display:flex}.pin-tooltip-row strong{color:var(--text-primary)}.pin-tooltip-row.price-highlight{border-top:1px solid var(--border-light);margin-top:4px;padding-top:6px}.price-value{color:var(--accent-hot)!important;font-size:14px!important}.pin-tooltip-footer{background:var(--primary-light);color:var(--primary);text-align:center;padding:8px 12px;font-size:11px;font-weight:600}.unit-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s modalOverlayIn;display:flex;position:fixed;inset:0}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.unit-modal{border-radius:var(--radius-xl);width:100%;max-width:960px;max-height:85vh;box-shadow:var(--shadow-xl);background:#fff;animation:.3s modalSlideIn;overflow-y:auto}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.unit-modal-header{border-bottom:1px solid var(--border-light);background:var(--bg-subtle);border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:space-between;align-items:flex-start;padding:24px 28px;display:flex}.unit-modal-title{color:var(--text-primary);margin-bottom:12px;font-size:26px;font-weight:800}.unit-modal-quick-info{gap:20px;display:flex}.quick-info-item{color:var(--primary);align-items:center;gap:8px;display:flex}.quick-info-item div{flex-direction:column;display:flex}.qi-label{color:var(--text-muted);font-size:11px;font-weight:500}.quick-info-item strong{color:var(--text-primary);font-size:14px}.unit-modal-header-right{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.unit-modal-price-tag{text-align:right}.price-tag-label{color:var(--text-muted);font-size:12px}.price-tag-value{color:var(--accent-hot);font-size:28px;font-weight:800;line-height:1.2;display:block}.price-tag-note{color:var(--text-muted);font-size:11px}.unit-modal-close{color:var(--text-muted);transition:all var(--transition-fast);border-radius:50%;padding:8px}.unit-modal-close:hover{background:var(--border-light);color:var(--text-primary)}.unit-modal-body{gap:0;min-height:400px;display:flex}.unit-modal-images{border-right:1px solid var(--border-light);flex-direction:column;flex-shrink:0;width:460px;display:flex}.unit-image-main{height:280px;position:relative;overflow:hidden}.unit-image-main img{object-fit:cover;width:100%;height:100%}.img-nav{width:32px;height:32px;color:var(--text-primary);box-shadow:var(--shadow-md);transition:all var(--transition-fast);background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.img-nav:hover{box-shadow:var(--shadow-lg);background:#fff}.img-nav.prev{left:8px}.img-nav.next{right:8px}.unit-image-badges{gap:6px;display:flex;position:absolute;top:12px;left:12px}.badge-type{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border-radius:var(--radius-sm);background:#0009;padding:4px 10px;font-size:11px;font-weight:600}.badge-fund{color:#fff;border-radius:var(--radius-sm);padding:4px 10px;font-size:11px;font-weight:600}.unit-image-actions{border-top:1px solid var(--border-light);gap:8px;padding:12px 16px;display:flex}.img-action{border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-light);transition:all var(--transition-fast);flex:1;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:13px;font-weight:500;display:flex}.img-action:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.unit-modal-details{flex-direction:column;flex:1;display:flex;overflow-y:auto}.unit-detail-tabs{border-bottom:2px solid var(--border-light);z-index:5;background:#fff;padding:0 24px;display:flex;position:sticky;top:0}.udt-tab{color:var(--text-secondary);transition:all var(--transition-fast);border-bottom:3px solid #0000;margin-bottom:-2px;padding:14px 20px;font-size:14px;font-weight:600}.udt-tab:hover{color:var(--primary)}.udt-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.unit-detail-content{padding:20px 24px}.detail-section{border-bottom:1px solid var(--border-light);margin-bottom:20px;padding-bottom:16px}.detail-section:last-of-type{border-bottom:none}.detail-section h3{color:var(--text-primary);margin-bottom:10px;font-size:14px;font-weight:700}.detail-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.detail-section-header h3{margin-bottom:0}.price-actions{gap:6px;display:flex}.price-action-btn{border-radius:var(--radius-sm);color:var(--primary);border:1px solid var(--primary);transition:all var(--transition-fast);background:#fff;align-items:center;gap:4px;padding:5px 10px;font-size:11px;font-weight:600;display:flex}.price-action-btn:hover{background:var(--primary);color:#fff}.price-grid{gap:6px;display:grid}.price-row{justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;display:flex}.price-row span{color:var(--text-secondary)}.price-row strong{color:var(--text-primary)}.area-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.area-item{justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.area-item span{color:var(--text-secondary)}.area-item strong{color:var(--text-primary)}.csbh-info,.handover-info,.status-info{font-size:13px}.csbh-row,.handover-row{justify-content:space-between;padding:4px 0;display:flex}.csbh-row span,.handover-row span{color:var(--text-secondary)}.csbh-desc{margin-top:4px}.csbh-desc span{color:var(--text-muted);font-size:12px}.csbh-desc p{color:var(--text-primary);margin-top:2px;font-size:13px}.status-info{justify-content:space-between;align-items:center;display:flex}.unit-status-badge{border-radius:var(--radius-full);color:#fff;padding:5px 14px;font-size:12px;font-weight:700}.status-meta{color:var(--text-muted);text-align:right;font-size:12px}.status-meta strong{color:var(--text-secondary);display:block}.lock-can-btn{border-radius:var(--radius-md);color:#fff;width:100%;transition:all var(--transition-base);letter-spacing:.05em;background:linear-gradient(135deg,#0058dd 0%,#003e9d 100%);justify-content:center;align-items:center;gap:8px;margin:16px 0;padding:14px;font-size:16px;font-weight:700;display:flex;box-shadow:0 4px 14px #0058dd59}.lock-can-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0058dd80}.lock-can-btn:disabled{background:var(--border-medium);color:var(--text-muted);box-shadow:none;cursor:not-allowed}.loan-calculator{border-radius:var(--radius-md);background:linear-gradient(135deg,#ebf4ff 0%,#f0f4fa 100%);border:1px solid #bfdbfe;margin-bottom:16px;padding:16px;animation:.3s slideDown}.loan-calculator h4{color:var(--text-primary);margin-bottom:12px;font-size:14px}.loan-inputs{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.loan-input-group{align-items:center;gap:10px;display:flex}.loan-input-group label{width:120px;color:var(--text-secondary);flex-shrink:0;font-size:12px}.loan-input-group input[type=range]{appearance:none;background:#bfdbfe;border-radius:3px;outline:none;flex:1;height:6px}.loan-input-group input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #0058dd4d}.loan-input-value{text-align:right;width:50px;color:var(--primary);font-size:13px;font-weight:700}.loan-results{border-top:1px solid #bfdbfe;padding-top:12px}.loan-result-item{justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.loan-result-item span{color:var(--text-secondary)}.monthly-payment{color:var(--accent-hot)!important;font-size:16px!important}.price-sheet{border-radius:var(--radius-md);background:#fffbeb;border:1px solid #fde68a;margin-bottom:16px;padding:16px;animation:.3s slideDown}.price-sheet h4{margin-bottom:12px;font-size:14px}.price-sheet-table{border-collapse:collapse;width:100%;font-size:13px}.price-sheet-table td{border-bottom:1px solid #fde68a;padding:6px 0}.price-sheet-table .text-right{text-align:right}.price-sheet-table .text-green{color:#16a34a}.price-sheet-table .text-blue{color:var(--primary)}.price-sheet-table .total-row{background:#fef3c7}.price-sheet-table .total-row td{padding:8px 4px}.contact-section{margin-top:8px}.contact-section h3{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;font-size:13px;font-weight:700}.contact-cards{flex-direction:column;gap:10px;display:flex}.contact-card{background:var(--bg-subtle);border-radius:var(--radius-md);border:1px solid var(--border-light);align-items:center;gap:12px;padding:10px 12px;display:flex}.contact-avatar{flex-shrink:0;position:relative}.contact-avatar img{border-radius:50%;width:40px;height:40px}.online-dot{background:#22c55e;border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;right:0}.contact-info{flex:1}.contact-info strong{font-size:13px;display:block}.contact-info span{color:var(--text-muted);font-size:11px}.contact-actions{gap:6px;display:flex}.contact-btn{color:#fff;width:32px;height:32px;transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.phone-btn{background:#22c55e}.zalo-btn{background:#0068ff}.contact-btn:hover{transform:scale(1.1)}.qa-tab .qa-empty{height:200px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.admin-editor{background:var(--bg-dark-2);color:#e2e8f0;height:100vh;font-family:var(--font-primary);flex-direction:column;display:flex;overflow:hidden}.admin-editor-header{background:var(--bg-dark);border-bottom:2px solid var(--accent-gold);flex-shrink:0;align-items:center;gap:16px;padding:12px 20px;display:flex}.admin-editor-logo{width:auto;height:34px;display:block}.admin-editor-back{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #475569;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:all .2s;display:flex}.admin-editor-back:hover{color:#e2e8f0;background:#334155}.admin-editor-title{color:#f1f5f9;margin:0;font-size:18px;font-weight:700}.admin-editor-project-select select{color:#e2e8f0;cursor:pointer;background:#1e293b;border:1px solid #475569;border-radius:6px;padding:6px 12px;font-size:13px}.admin-editor-actions{gap:8px;margin-left:auto;display:flex}.admin-btn{color:#cbd5e1;cursor:pointer;background:#334155;border:1px solid #475569;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;transition:all .2s;display:flex}.admin-btn:hover{color:#f1f5f9;background:#475569}.admin-btn-primary{color:#fff;background:#224c92;border-color:#2a5aa8}.admin-btn-primary:hover{background:var(--primary-dark)}.admin-editor-body{flex-direction:column;flex:1;min-height:0;display:flex}.admin-editor-toolbar{background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0;align-items:center;gap:16px;padding:8px 20px;display:flex}.admin-toolbar-group{align-items:center;gap:4px;display:flex}.admin-toolbar-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-right:4px;font-size:12px}.admin-tool-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:5px;padding:6px 10px;font-size:12px;transition:all .15s;display:flex}.admin-tool-btn:hover{color:#e2e8f0;background:#334155}.admin-tool-btn.active{color:#fff;background:#224c92;border-color:#2a5aa8}.admin-tool-btn:disabled{opacity:.4;cursor:not-allowed}.admin-toolbar-hint{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33;border-radius:4px;margin-left:auto;padding:4px 12px;font-size:12px}.admin-editor-content{flex:1;min-height:0;display:flex}.admin-editor-canvas{background:#0a0f1a;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.admin-canvas-inner{display:inline-block;position:relative}.admin-canvas-image{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;max-width:100%;max-height:calc(100vh - 130px);display:block}.admin-canvas-svg{width:100%;height:100%;position:absolute;top:0;left:0}.admin-zone-polygon{cursor:pointer;transition:fill-opacity .15s}.admin-zone-polygon:hover{fill-opacity:.45!important}.admin-zone-vertex{cursor:move;transition:r .1s}.admin-zone-vertex:hover{r:.9}.admin-editor-sidebar{background:#1e293b;border-left:1px solid #334155;flex-direction:column;flex-shrink:0;width:320px;display:flex}.admin-sidebar-header{border-bottom:1px solid #334155;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.admin-sidebar-header h3{color:#f1f5f9;margin:0;font-size:14px;font-weight:600}.admin-sidebar-count{color:#fff;background:#224c92;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.admin-sidebar-list{flex:1;padding:8px;overflow-y:auto}.admin-sidebar-empty{text-align:center;color:#64748b;padding:32px 16px;font-size:13px;line-height:1.6}.admin-zone-item{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:stretch;gap:8px;margin-bottom:4px;padding:10px 12px;transition:all .15s;display:flex}.admin-zone-item:hover{background:#334155}.admin-zone-item.selected{background:#2563eb26;border-color:#224c92}.admin-zone-item-indicator{border-radius:2px;flex-shrink:0;width:4px}.admin-zone-item-content{flex:1;min-width:0}.admin-zone-item-info{flex-direction:column;gap:2px;display:flex}.admin-zone-code{color:#f1f5f9;font-size:13px;font-weight:600}.admin-zone-no-code{color:#64748b;font-weight:400}.admin-zone-status{font-size:11px;font-weight:500}.admin-zone-vertices{color:#64748b;font-size:11px}.admin-zone-item-actions{opacity:0;align-items:center;gap:2px;transition:opacity .15s;display:flex}.admin-zone-item:hover .admin-zone-item-actions{opacity:1}.admin-zone-item-actions button{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:all .15s;display:flex}.admin-zone-item-actions button:hover{color:#f1f5f9;background:#475569}.admin-zone-code-edit{align-items:center;gap:4px;display:flex}.admin-zone-code-edit input{color:#f1f5f9;background:#0f172a;border:1px solid #2a5aa8;border-radius:4px;outline:none;flex:1;padding:4px 8px;font-size:13px}.admin-zone-code-edit button{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;display:flex}.admin-zone-code-edit button:first-of-type:hover{color:#22c55e}.admin-zone-code-edit button:last-of-type:hover{color:#ef4444}.admin-sidebar-legend{border-top:1px solid #334155;padding:12px 16px}.admin-sidebar-legend h4{text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin:0 0 8px;font-size:11px}.admin-legend-item{color:#94a3b8;align-items:center;gap:8px;padding:3px 0;font-size:12px;display:flex}.admin-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.zone-overlay-svg{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.zone-polygon{pointer-events:auto;cursor:pointer;transition:fill-opacity .2s,stroke-width .2s}.zone-polygon:hover{fill-opacity:.5!important;stroke-width:.4px!important}.zone-polygon.no-data{pointer-events:none;fill-opacity:0!important;stroke-opacity:0!important}.zone-label-text{pointer-events:none;text-shadow:0 1px 3px #000000b3;font-weight:700}.zone-tooltip{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f1f5f9;pointer-events:none;background:#0f172af2;border:1px solid #ffffff1a;border-radius:10px;min-width:200px;padding:12px 16px;font-size:13px;position:absolute;transform:translate(-50%,-110%);box-shadow:0 8px 32px #0006}.zone-tooltip-code{margin-bottom:6px;font-size:15px;font-weight:700}.zone-tooltip-row{color:#94a3b8;justify-content:space-between;padding:2px 0;display:flex}.zone-tooltip-row span:last-child{color:#f1f5f9;font-weight:500}.zone-tooltip-price{color:#f59e0b;text-align:center;border-top:1px solid #334155;margin-top:6px;padding-top:6px;font-size:16px;font-weight:700}.user-menu{position:relative}.user-menu-trigger{border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:pointer;background:#fff;align-items:center;gap:8px;padding:6px 10px 6px 6px;transition:all .2s;display:flex}.user-menu-trigger:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:grid}.user-avatar.lg{width:44px;height:44px;font-size:18px}.user-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:14px;font-weight:600;overflow:hidden}.user-dropdown{border:1px solid var(--border-light);border-radius:var(--radius-md);min-width:230px;box-shadow:var(--shadow-lg);z-index:200;background:#fff;padding:8px;animation:.15s fadeInDown;position:absolute;top:calc(100% + 8px);right:0}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-head{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;margin-bottom:6px;padding:8px 10px 12px;display:flex}.user-dropdown-name{font-size:14px;font-weight:700}.user-dropdown-role{color:var(--text-muted);font-size:12px}.user-dropdown-item{border-radius:var(--radius-sm);width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px;font-size:14px;transition:background .15s;display:flex}.user-dropdown-item:hover{background:var(--bg-secondary,#f3f4f6)}.user-dropdown-item.danger{color:#dc2626}.user-dropdown-item.danger:hover{background:#fef2f2}.img-action.active{color:#ef4444;background:#fef2f2;border-color:#fecaca}.lock-form{border-radius:var(--radius-md);background:#eff6ff;border:1px solid #bfdbfe;margin-top:8px;padding:16px}.lock-form h4{align-items:center;gap:8px;margin-bottom:12px;font-size:15px;display:flex}.lock-form input,.lock-form textarea{border-radius:var(--radius-sm);border:1px solid #d1d5db;width:100%;margin-bottom:10px;padding:10px 12px;font-family:inherit;font-size:14px}.lock-form-actions{justify-content:flex-end;gap:10px;display:flex}.admin-page{background:var(--bg-body);min-height:100vh;padding-top:var(--header-height)}.admin-content{padding:28px 0 64px}.admin-content-title{color:var(--primary);letter-spacing:-.01em;margin:0 0 22px;font-size:24px;font-weight:800}.admin-loading{text-align:center;padding:48px}.admin-field{flex-direction:column;gap:4px;font-size:13px;display:flex}.admin-label{color:var(--text-muted);font-weight:600}.admin-card{border:1px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;padding:20px}.admin-page-header{border-bottom:1px solid var(--border-light);background:#fff;align-items:center;gap:18px;padding:12px 24px;display:flex}.admin-brand{flex-shrink:0;align-items:center;display:flex}.admin-brand-logo{width:auto;height:38px;display:block}.admin-page-title{border-left:1px solid var(--border-light);font-family:var(--font-heading);color:var(--primary);letter-spacing:-.01em;flex:1;margin:0;padding-left:18px;font-size:21px;font-weight:800}.admin-home-btn{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary);cursor:pointer;white-space:nowrap;transition:all var(--transition-base);border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.admin-home-btn:hover{background:var(--primary);color:#fff}.admin-tabs{border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);top:var(--header-height);z-index:20;background:#fff;position:sticky}.admin-tabs-row{gap:2px;display:flex;overflow-x:auto}.admin-tabs a{color:var(--text-secondary);white-space:nowrap;transition:all var(--transition-base);border-bottom:3px solid #0000;padding:14px 18px;font-size:14px;font-weight:600;text-decoration:none}.admin-tabs a:hover{color:var(--primary);background:var(--bg-subtle)}.admin-tabs a.active{color:var(--primary);border-bottom-color:var(--accent-gold)}.info-page{margin-top:var(--header-height);min-height:70vh}.info-hero{background:var(--primary-gradient);color:#fff;padding:48px 0 40px}.info-hero h1{margin-bottom:8px;font-size:34px;font-weight:900}.info-lead{opacity:.85;max-width:760px;line-height:1.7}.info-updated{opacity:.7;margin-top:10px;font-size:13px}.info-content{max-width:820px}.info-content h2{color:var(--primary);margin:32px 0 12px;font-size:20px;font-weight:800}.info-content h2:first-child{margin-top:0}.info-content h3{margin:20px 0 8px;font-size:16px;font-weight:700}.info-content p{color:var(--text-secondary);margin-bottom:12px;line-height:1.8}.info-content ul,.info-content ol{color:var(--text-secondary);margin:0 0 14px 22px;line-height:1.8}.info-content li{margin-bottom:6px}.info-content a{color:var(--primary)}.info-content strong{color:var(--text-primary)}.info-note{background:var(--bg-subtle);border-left:3px solid var(--accent-gold);color:var(--text-secondary);border-radius:8px;margin:18px 0;padding:12px 16px;font-size:14px}.faq-item{border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:12px;padding:16px 18px}.faq-item h3{color:var(--text-primary);margin:0 0 6px}.faq-item p{margin:0}.toast-viewport{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;max-width:min(380px,100vw - 32px);display:flex;position:fixed;top:16px;right:16px}.toast{pointer-events:auto;border:1px solid var(--border-light);color:var(--text-primary);background:#fff;border-radius:10px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:14px;font-weight:600;animation:.22s toast-in;display:flex;box-shadow:0 8px 24px #00000024}.toast-icon{flex-shrink:0;margin-top:1px}.toast-text{word-break:break-word;flex:1;line-height:1.4}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:6px;flex-shrink:0;padding:2px;display:inline-flex}.toast-close:hover{background:var(--bg-subtle);color:var(--text-primary)}.toast--success{border-left:4px solid #16a34a}.toast--success .toast-icon{color:#16a34a}.toast--error{border-left:4px solid #dc2626}.toast--error .toast-icon{color:#dc2626}.toast--info{border-left:4px solid var(--primary)}.toast--info .toast-icon{color:var(--primary)}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.toast-viewport{max-width:none;inset:auto 16px 16px}}
