*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans SC",sans-serif;background:#f5f5f5}.container{display:flex;height:100vh}#map-container{flex:1;position:relative}#map{width:100%;height:100%}.sidebar{width:400px;background:#fff;box-shadow:-2px 0 10px rgba(0,0,0,.1);overflow-y:auto;padding:20px;z-index:1000}.sidebar h2{margin-bottom:15px;color:#333;font-size:18px}.config-info{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:15px;border-radius:8px;margin-bottom:20px;font-size:13px}.config-info strong{display:block;margin-bottom:8px;font-size:14px}.config-info code{background:rgba(255,255,255,.2);padding:2px 6px;border-radius:4px;font-family:'Courier New',monospace;font-size:12px}.legend{background:#f9f9f9;padding:15px;border-radius:8px;margin-bottom:20px}.legend h3{font-size:14px;margin-bottom:10px;color:#666}.legend-item{display:flex;align-items:center;margin-bottom:8px;font-size:13px}.legend-color{width:16px;height:16px;border-radius:50%;margin-right:10px;border:2px solid #333;flex-shrink:0}.tier-1{background:gold}.tier-2{background:#87ceeb}.tier-3{background:#90ee90}.tier-4{background:#d3d3d3}.home{background:#ff6b6b}.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.stat-card{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:15px;border-radius:8px;text-align:center}.stat-number{font-size:24px;font-weight:700}.stat-label{font-size:12px;opacity:.9}.school-list{margin-top:10px}.section-title{font-size:14px;font-weight:600;color:#666;margin:15px 0 10px;padding-bottom:5px;border-bottom:2px solid #eee}.school-item{padding:12px;margin-bottom:8px;border-radius:8px;cursor:pointer;transition:.2s;border-left:4px solid transparent}.school-item:hover{transform:translateX(5px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.school-item.tier-1{border-left-color:gold;background:#fffae6}.school-item.tier-2{border-left-color:#87ceeb;background:#e6f7ff}.school-item.tier-3{border-left-color:#90ee90;background:#e6ffe6}.school-item.tier-4{border-left-color:#d3d3d3;background:#f5f5f5}.school-name{font-weight:600;color:#333;margin-bottom:4px;font-size:14px}.school-info{font-size:12px;color:#666}.school-rate{color:#ff6b6b;font-weight:600}.home-marker{background:linear-gradient(135deg,#ffe6e6 0,pink 100%);border-left-color:#ff6b6b}.school-detail-btn{display:inline-block;margin-top:8px;padding:6px 12px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;text-decoration:none;transition:.2s}.school-detail-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}#school-detail-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:9999;justify-content:center;align-items:center}#school-detail-modal .modal-content{background:#fff;border-radius:12px;max-width:800px;width:90%;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}#school-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff}#school-detail-modal .modal-header h3{margin:0;font-size:18px}#school-detail-modal .close-btn{background:0 0;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}#school-detail-modal .modal-body{padding:20px;overflow-y:auto;max-height:calc(80vh - 60px)}#school-detail-modal .modal-body h1{font-size:24px;color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #667eea}#school-detail-modal .modal-body h2{font-size:18px;color:#667eea;margin:20px 0 10px;padding-bottom:8px;border-bottom:1px solid #eee}#school-detail-modal .modal-body p{line-height:1.6;color:#333;margin:10px 0}#school-detail-modal .modal-body.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#999}#school-detail-modal .modal-body.error{display:flex;justify-content:center;align-items:center;min-height:200px;color:#dc3545}@media (max-width:768px){.container{flex-direction:column}.sidebar{width:100%;max-height:40vh;order:2}#map-container{height:60vh;order:1}}#access-code-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);z-index:99999;justify-content:center;align-items:center}#access-code-modal .access-code-content{background:#fff;border-radius:16px;padding:40px;max-width:450px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center}#access-code-modal .access-code-content h3{font-size:24px;color:#333;margin-bottom:15px}#access-code-modal .access-code-content p{font-size:14px;color:#666;margin-bottom:25px;line-height:1.6}#access-code-modal #access-code-input{width:100%;padding:15px;border:2px solid #ddd;border-radius:8px;font-size:16px;margin-bottom:15px;box-sizing:border-box;transition:border-color .2s}#access-code-modal #access-code-input:focus{outline:0;border-color:#667eea}#access-code-modal #access-code-error{margin-bottom:15px;font-size:14px;padding:10px;background:#ffe6e6;border-radius:6px}#access-code-modal #access-code-confirm-btn{width:100%;padding:15px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:.2s}#access-code-modal #access-code-confirm-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}