:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#0f172a;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:transparent;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:transparent}}.community-container{padding:1%;min-height:100vh;background:#f8fafc}.header{z-index:1000!important;position:sticky!important;top:0!important}.post-detail-container{z-index:10!important}.header-button{z-index:1001!important;position:relative!important}.community-header{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:24px}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.title-section h2{font-size:28px;font-weight:800;color:#1e293b;margin:0 0 8px}.title-section p{color:#64748b;margin:0;font-size:16px}.write-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f666}.write-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f680}.category-filter{display:flex;gap:12px;flex-wrap:wrap}.category-btn{padding:10px 20px;border:2px solid #e2e8f0;background:#fff;border-radius:25px;font-weight:500;cursor:pointer;transition:all .2s;color:#64748b}.category-btn:hover{border-color:#3b82f6;color:#3b82f6}.category-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.community-main{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;min-height:600px}.loading{text-align:center;padding:48px;color:#64748b;font-size:18px}@media(max-width:768px){.community-container{padding:12px}.header-content{flex-direction:column;gap:16px;align-items:stretch}.category-filter{justify-content:center}}.post-list .post-card,.space-y-4>div{padding:24px;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s;cursor:pointer}.post-card:hover,.space-y-4>div:hover{box-shadow:0 10px 25px #0000001a;border-color:#3b82f6;background:#f8fafc}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bg-blue-100{background:#dbeafe}.text-blue-800{color:#1e40af}.bg-yellow-100{background:#fef3c7}.text-yellow-800{color:#92400e}.bg-green-100{background:#dcfce7}.text-green-800{color:#166534}input,textarea,select{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}input:focus,textarea:focus,select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}textarea{resize:vertical;min-height:300px;font-family:inherit}button{border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.text-gray-600{color:#6b7280}.hover\:text-gray-900:hover{color:#111827}.prose p{line-height:1.7;margin-bottom:1em;color:#374151}.prose h1{font-size:2.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.auth-modal{display:flex!important;align-items:center!important;justify-content:center!important;min-height:100vh!important;padding:1rem!important}.auth-container{background:#fff!important;border-radius:20px!important;box-shadow:0 25px 50px -12px #00000040!important;padding:3rem!important;width:100%!important;max-width:420px!important;max-height:90vh!important;overflow-y:auto!important;position:relative!important}.auth-title{text-align:center!important;margin-bottom:2rem!important;color:#1f2937!important;font-size:1.75rem!important;font-weight:700!important}.auth-input{width:100%!important;padding:1rem!important;border:1px solid #d1d5db!important;border-radius:12px!important;font-size:1rem!important;outline:none!important;transition:border-color .2s,box-shadow .2s!important;margin-bottom:1.25rem!important}.auth-input:focus{border-color:#2563eb!important;box-shadow:0 0 0 3px #2563eb1a!important;background:#fff!important}.auth-button{width:100%!important;padding:1rem!important;background:#2563eb!important;color:#fff!important;border:none!important;border-radius:12px!important;font-size:1rem!important;font-weight:600!important;cursor:pointer!important;transition:all .2s!important}.auth-button:hover:not(:disabled){background:#1d4ed8!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px #2563eb4d!important}.auth-button:disabled{background:#9ca3af!important;cursor:not-allowed!important}.auth-error{background:#fee2e2!important;color:#dc2626!important;padding:.75rem!important;border-radius:8px!important;margin-bottom:1.25rem!important;font-size:.875rem!important}.auth-switch-link{background:none!important;border:none!important;color:#2563eb!important;text-decoration:underline!important;cursor:pointer!important;font-weight:500!important;padding:0!important;font-size:.875rem!important}.auth-switch-link:hover{color:#1d4ed8!important}.auth-cancel-btn{width:100%!important;padding:.75rem!important;background:#f3f4f6!important;border:1px solid #d1d5db!important;color:#6b7280!important;border-radius:8px!important;cursor:pointer!important;font-size:.875rem!important;font-weight:500!important;margin-top:1rem!important}.auth-cancel-btn:hover{background:#e5e7eb!important}.auth-overlay{position:fixed!important;inset:0!important;background:#0009!important;-webkit-backdrop-filter:blur(12px)!important;backdrop-filter:blur(12px)!important;z-index:9999!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:1rem!important}.auth-overlay:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}@media(max-width:480px){.auth-container{padding:2rem 1.5rem!important;margin:1rem!important}.auth-title{font-size:1.5rem!important}}:root{--blue: #2563eb;--bg: #f8fafc;--border: #e2e8f0;--text: #0f172a}body,html{margin:0;padding:0;height:100%;width:100%;overflow:hidden;font-family:Pretendard,sans-serif}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:var(--bg)}.header{height:60px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 40px}main{flex:1;display:flex;flex-direction:column;padding:20px 40px;gap:20px;min-height:0;overflow-y:scroll}.filter-container{background:#fff;padding:24px 40px;border-radius:24px;border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:40px;box-shadow:0 4px 20px #0000000d;width:100%;box-sizing:border-box}.filter-item{display:flex;flex-direction:column;gap:8px;flex:1}.filter-label{font-size:13px;font-weight:800;color:var(--blue);margin-left:4px}.selected-display{font-size:18px;font-weight:900;color:var(--text);padding:10px 0;border-bottom:2px solid var(--border);min-height:28px}.select-input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--border);background-color:#f8fafc;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;outline:none;transition:all .2s}.select-input:focus{border-color:var(--blue);background-color:#fff;box-shadow:0 0 0 4px #2563eb1a}.analyze-btn{padding:16px 40px;background-color:var(--blue);color:#fff;border:none;border-radius:16px;font-size:16px;font-weight:800;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 4px 12px #2563eb4d}.analyze-btn:hover{background-color:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 15px #2563eb66}.analyze-btn:active{transform:translateY(0)}.filter-section{background:#fff;padding:20px 30px;border-radius:20px;border:1px solid var(--border);display:flex;align-items:flex-end;gap:30px;box-shadow:0 4px 6px #00000005}.dashboard-grid{display:grid;grid-template-columns:minmax(0,7.5fr) minmax(0,4.5fr);gap:24px;flex:1;min-height:0}.map-view,.side-view{background:#fff;border-radius:32px;border:1px solid var(--border);overflow:hidden;position:relative;display:flex;flex-direction:column;min-width:0}.scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 24px 24px}.card{background:#fff;border:1px solid var(--border);padding:20px;border-radius:20px;margin-bottom:16px}.score-hero{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;padding:32px;border-radius:24px;text-align:center;margin-bottom:20px}.marker-label{padding:8px 16px;background:#fff;border:2px solid var(--blue);border-radius:20px;font-weight:800;color:var(--blue);box-shadow:0 4px 12px #0000001a;cursor:pointer;white-space:nowrap;outline:15px solid transparent}.marker-label.active{background:#2563eb;color:#fff;border-color:#2eb4b5}.fade-in{animation:fadeIn .3s ease-out}.buttons-container{color:var(--blue-primary)}.header-button{display:flex;background-color:var(--blue);color:#fff;border:none;cursor:pointer;transition:all .2s;box-shadow:0 10px 15px -3px #fff3}.header-button:active{transform:scale(.95)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
