@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;900&display=swap";:root{--primary: #1b4332;--primary-light: #2d6a4f;--primary-lighter: #40916c;--accent: #52b788;--accent-light: #95d5b2;--accent-lightest: #d8f3dc;--bg: #f0f7f4;--bg-card: rgba(255, 255, 255, .88);--bg-glass: rgba(255, 255, 255, .65);--border: rgba(45, 106, 79, .12);--text: #1a2e1c;--text-muted: #6b7280;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--radius: 16px;--radius-sm: 10px;--radius-full: 999px;--sidebar-width: 300px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}.navbar{position:sticky;top:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:60px;background:var(--bg-glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none}.navbar-brand .logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:900;flex-shrink:0}.navbar-brand h1{font-size:18px;font-weight:900;letter-spacing:1.5px;background:linear-gradient(135deg,var(--primary),var(--primary-lighter));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.navbar-links{display:flex;align-items:center;gap:4px}.navbar-links a{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-muted);transition:all .2s}.navbar-links a:hover,.navbar-links a.active{color:var(--primary);background:var(--accent-lightest)}.nav-divider{width:1px;height:20px;background:var(--border);margin:0 4px}.nav-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--text-muted);transition:all .2s}.nav-icon-btn:hover{color:var(--primary);background:var(--accent-lightest)}.nav-community-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;color:#fff;background:#fee500;color:#381e1f;transition:all .2s}.nav-community-btn:hover{background:#fdd835;transform:translateY(-1px)}.lang-toggle{display:flex;align-items:center;background:var(--accent-lightest);border-radius:var(--radius-sm);padding:3px;gap:2px}.lang-btn{padding:4px 9px;border-radius:7px;font-size:12px;font-weight:700;color:var(--text-muted);transition:all .15s;cursor:pointer;background:none;border:none;font-family:inherit}.lang-btn.active{background:var(--primary);color:#fff}.lang-btn:hover:not(.active){color:var(--primary)}@media (max-width: 700px){.navbar{padding:8px 16px;flex-wrap:wrap;height:auto;gap:8px}.navbar-links{flex-wrap:wrap;gap:4px}.nav-community-btn span,.nav-community-btn{font-size:12px;padding:5px 10px}}.hero{padding:48px 32px 36px;text-align:center;background:linear-gradient(180deg,var(--accent-lightest) 0%,var(--bg) 100%);position:relative;overflow:hidden}.hero-bg-icon{position:absolute;font-size:240px;opacity:.04;top:-50px;right:-30px;animation:floatSlow 7s ease-in-out infinite;pointer-events:none;-webkit-user-select:none;user-select:none}@keyframes floatSlow{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-18px) rotate(4deg)}}.hero h2{font-size:38px;font-weight:900;color:var(--primary);margin-bottom:10px}.hero p{font-size:16px;color:var(--text-muted);max-width:520px;margin:0 auto;line-height:1.6}.hero-stats{display:flex;gap:40px;justify-content:center;margin-top:28px;flex-wrap:wrap}.hero-stat{text-align:center}.hero-stat .num{font-size:28px;font-weight:900;color:var(--primary)}.hero-stat .label{font-size:12px;color:var(--text-muted);margin-top:2px;font-weight:500}.main-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;gap:0;min-height:calc(100vh - 200px)}@media (max-width: 900px){.main-layout{grid-template-columns:1fr}}.sidebar{position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto;background:var(--bg-card);border-right:1px solid var(--border);padding:20px 16px;flex-shrink:0}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--accent-light);border-radius:2px}.filter-section{margin-bottom:22px}.filter-section-title{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px}.filter-reset-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);border:1px solid var(--border);background:transparent;transition:all .2s;margin-bottom:16px}.filter-reset-btn:hover{color:var(--primary);border-color:var(--accent);background:var(--accent-lightest)}.checkbox-group{display:flex;flex-direction:column;gap:6px}.checkbox-item{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text);padding:5px 8px;border-radius:var(--radius-sm);transition:background .15s}.checkbox-item:hover{background:var(--accent-lightest)}.checkbox-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);flex-shrink:0}.filter-select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:13px;font-family:inherit;color:var(--text);outline:none;transition:border-color .2s}.filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #52b7881f}.slider-container{display:flex;flex-direction:column;gap:8px}.slider-row{display:flex;align-items:center;gap:10px}.slider-label{font-size:12px;color:var(--text-muted);min-width:60px}.slider-value{font-size:12px;font-weight:700;color:var(--primary);min-width:20px;text-align:right}input[type=range]{flex:1;height:4px;accent-color:var(--primary);cursor:pointer}.toggle-group{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.toggle-btn{flex:1;padding:7px 10px;font-size:12px;font-weight:600;text-align:center;border:none;background:transparent;cursor:pointer;transition:all .2s;color:var(--text-muted)}.toggle-btn.active{background:var(--primary);color:#fff}.tag-select-grid{display:flex;flex-wrap:wrap;gap:5px}.tag-select-item{padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .15s;color:var(--text-muted)}.tag-select-item.active{background:var(--primary);color:#fff;border-color:var(--primary)}.tag-select-item:hover:not(.active){border-color:var(--accent);color:var(--primary)}.height-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}.height-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #52b7881f}.results-area{padding:20px 24px;min-height:100%}.search-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-input-wrap{position:relative;flex:1;min-width:200px}.search-input-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:10px 16px 10px 40px;border:1px solid var(--border);border-radius:var(--radius-full);background:#fff;font-size:14px;font-family:inherit;outline:none;transition:all .2s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #52b7881f}.results-count{font-size:13px;color:var(--text-muted);font-weight:500;white-space:nowrap}.results-count strong{color:var(--primary);font-weight:700}.species-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.species-card{background:var(--bg-card);border-radius:var(--radius);border:1.5px solid transparent;box-shadow:var(--shadow-sm);cursor:pointer;transition:all .25s ease;overflow:hidden;display:flex;flex-direction:column}.species-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent-light)}.card-header{padding:16px 16px 12px;background:linear-gradient(135deg,var(--accent-lightest),rgba(255,255,255,.5));display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.card-plant-icon{font-size:32px;line-height:1}.card-type-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--radius-full);background:var(--primary);color:#fff;flex-shrink:0}.card-type-badge.shrub{background:#065f46}.card-type-badge.herb{background:#92400e}.card-type-badge.ground{background:#1d4ed8}.card-type-badge.flower{background:#9d174d}.card-body{padding:12px 16px 14px;flex:1;display:flex;flex-direction:column;gap:4px}.card-korean-name{font-size:15px;font-weight:700;color:var(--primary);line-height:1.3}.card-sci-name{font-size:11px;color:var(--text-muted);font-style:italic;line-height:1.4}.card-family{font-size:11px;color:var(--accent);font-weight:600;margin-top:2px}.card-meta{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.card-meta-item{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--text-muted)}.card-meta-item svg{color:var(--accent);flex-shrink:0}.card-tolerances{display:flex;gap:4px;margin-top:10px}.tol-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tol-dot.filled{background:var(--primary)}.tol-dot.empty{background:var(--border);border:1px solid var(--accent-light)}.card-carbon{display:flex;align-items:center;gap:4px;margin-top:8px;font-size:11px;font-weight:600;color:var(--primary-lighter)}.card-evergreen-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:var(--radius-full);margin-top:6px;width:fit-content}.card-evergreen-badge.evergreen{background:#ecfdf5;color:#065f46}.card-evergreen-badge.deciduous{background:#fef3c7;color:#92400e}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:32px;padding-bottom:32px}.page-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--primary)}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-info{font-size:13px;color:var(--text-muted);padding:0 8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:flex-start;justify-content:center;padding:20px 16px;overflow-y:auto}.modal-panel{background:#fff;border-radius:24px;width:100%;max-width:720px;box-shadow:var(--shadow-lg);overflow:hidden;position:relative}.modal-close-btn{position:absolute;top:16px;right:16px;z-index:10;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0000000f;color:var(--text-muted);transition:all .2s;border:none;cursor:pointer}.modal-close-btn:hover{background:#0000001f;color:var(--text)}.modal-hero{padding:28px 28px 20px;background:linear-gradient(135deg,var(--accent-lightest) 0%,rgba(255,255,255,.8) 100%);position:relative}.modal-hero-top{display:flex;align-items:flex-start;gap:16px}.modal-plant-icon{font-size:56px;line-height:1;flex-shrink:0}.modal-title-group{flex:1;min-width:0}.modal-korean-name{font-size:28px;font-weight:900;color:var(--primary);line-height:1.2}.modal-sci-name{font-size:14px;color:var(--text-muted);font-style:italic;margin-top:4px}.modal-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600}.badge-type{background:var(--primary);color:#fff}.badge-zone{background:#dbeafe;color:#1e40af}.badge-evergreen{background:#ecfdf5;color:#065f46}.badge-deciduous{background:#fef3c7;color:#92400e}.modal-body{padding:24px 28px;display:flex;flex-direction:column;gap:24px}.modal-section-title{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.tolerance-grid{display:flex;flex-direction:column;gap:10px}.tolerance-row{display:flex;align-items:center;gap:12px}.tolerance-label{font-size:12px;font-weight:600;color:var(--text-muted);width:60px;flex-shrink:0}.tolerance-bar-track{flex:1;height:8px;background:var(--accent-lightest);border-radius:var(--radius-full);overflow:hidden}.tolerance-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s ease}.tolerance-bar-fill.drought{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.tolerance-bar-fill.cold{background:linear-gradient(90deg,#60a5fa,#3b82f6)}.tolerance-bar-fill.shade{background:linear-gradient(90deg,#a78bfa,#8b5cf6)}.tolerance-bar-fill.pollution{background:linear-gradient(90deg,#34d399,#10b981)}.tolerance-bar-fill.maintenance{background:linear-gradient(90deg,#fb923c,#ef4444)}.tolerance-value{font-size:12px;font-weight:700;color:var(--primary);min-width:28px;text-align:right}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media (max-width: 600px){.info-grid{grid-template-columns:1fr}}.info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04);gap:12px}.info-row:last-child{border-bottom:none}.info-row .lbl{font-size:12px;color:var(--text-muted);flex-shrink:0}.info-row .val{font-size:12px;font-weight:600;text-align:right}.tag-cloud{display:flex;flex-wrap:wrap;gap:6px}.tag-pill{padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500}.tag-pill.landscape{background:var(--accent-lightest);color:var(--primary);border:1px solid var(--accent-light)}.tag-pill.ecological{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.carbon-highlight{display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:var(--radius);border:1px solid #a7f3d0}.carbon-num{font-size:28px;font-weight:900;color:var(--primary);line-height:1}.carbon-unit{font-size:12px;color:var(--primary-lighter);font-weight:600}.description-text{font-size:14px;line-height:1.8;color:#374151;white-space:pre-line}.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;color:var(--text-muted);font-size:14px}.spinner{width:40px;height:40px;border:3px solid var(--accent-lightest);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center;gap:12px}.empty-state-icon{font-size:48px;opacity:.4}.empty-state h3{font-size:16px;font-weight:700;color:var(--text)}.empty-state p{font-size:14px}.page-container{max-width:900px;margin:0 auto;padding:32px 24px 60px}.page-title{font-size:28px;font-weight:900;color:var(--primary);margin-bottom:6px}.page-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:32px;line-height:1.6}.calc-search-box{position:relative;margin-bottom:24px}.calc-search-box svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.calc-search-input{width:100%;padding:12px 16px 12px 44px;border:1px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit;outline:none;background:#fff;transition:all .2s}.calc-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #52b7881f}.calc-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;max-height:300px;overflow-y:auto}.calc-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .15s;gap:12px}.calc-dropdown-item:hover{background:var(--accent-lightest)}.calc-dropdown-item .korean{font-size:14px;font-weight:600}.calc-dropdown-item .sci{font-size:12px;color:var(--text-muted);font-style:italic}.calc-dropdown-item .carbon-info{font-size:12px;font-weight:600;color:var(--primary-lighter);white-space:nowrap}.calc-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.calc-entry{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.calc-entry-info{flex:1;min-width:0}.calc-entry-info .korean{font-size:15px;font-weight:700;color:var(--primary)}.calc-entry-info .sci{font-size:12px;color:var(--text-muted);font-style:italic}.calc-count-wrap{display:flex;align-items:center;gap:8px}.calc-count-btn{width:28px;height:28px;border-radius:8px;background:var(--accent-lightest);color:var(--primary);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s}.calc-count-btn:hover{background:var(--accent-light)}.calc-count-input{width:56px;text-align:center;padding:4px 6px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;outline:none}.calc-entry-carbon{font-size:14px;font-weight:700;color:var(--primary-lighter);white-space:nowrap;min-width:80px;text-align:right}.calc-remove-btn{color:var(--text-muted);background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;transition:all .15s;display:flex}.calc-remove-btn:hover{background:#fee2e2;color:#ef4444}.calc-result-card{padding:28px;background:linear-gradient(135deg,var(--primary),var(--primary-lighter));border-radius:var(--radius);color:#fff;text-align:center}.calc-result-card h3{font-size:16px;font-weight:600;opacity:.85;margin-bottom:12px}.calc-result-num{font-size:52px;font-weight:900;line-height:1;margin-bottom:6px}.calc-result-unit{font-size:14px;opacity:.75;margin-bottom:20px}.calc-result-equiv{font-size:13px;opacity:.7;line-height:1.6}.stats-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:40px}.stats-kpi-card{padding:20px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:center}.stats-kpi-card .kpi-num{font-size:32px;font-weight:900;color:var(--primary);line-height:1;margin-bottom:4px}.stats-kpi-card .kpi-label{font-size:12px;color:var(--text-muted);font-weight:500}.stats-section{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.stats-section-title{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:20px}.bar-chart{display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;align-items:center;gap:12px}.bar-label{font-size:12px;font-weight:600;color:var(--text);min-width:100px;text-align:right}.bar-track{flex:1;height:20px;background:var(--accent-lightest);border-radius:var(--radius-full);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .8s ease}.bar-value{font-size:12px;font-weight:700;color:var(--primary);min-width:50px}.pie-chart-wrap{display:flex;align-items:center;gap:32px;flex-wrap:wrap}.pie-chart-svg{flex-shrink:0}.pie-legend{display:flex;flex-direction:column;gap:8px}.pie-legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.pie-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.pie-legend-label{font-weight:600;color:var(--text)}.pie-legend-count{color:var(--text-muted);font-size:12px}.top-carbon-list{display:flex;flex-direction:column;gap:8px}.top-carbon-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--bg)}.top-carbon-rank{font-size:13px;font-weight:900;color:var(--primary);min-width:24px;text-align:center}.top-carbon-info{flex:1;min-width:0}.top-carbon-korean{font-size:13px;font-weight:700}.top-carbon-sci{font-size:11px;color:var(--text-muted);font-style:italic}.top-carbon-value{font-size:13px;font-weight:700;color:var(--primary-lighter);white-space:nowrap}.footer{padding:32px;text-align:center;font-size:13px;color:var(--text-muted);border-top:1px solid var(--border)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .4s ease-out both}@media (max-width: 900px){.navbar{padding:0 16px}.hero{padding:32px 16px 24px}.hero h2{font-size:26px}.results-area{padding:16px}.sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--border)}.modal-overlay{padding:0}.modal-panel{border-radius:0;min-height:100vh}.page-container{padding:20px 16px 40px}.calc-entry{flex-wrap:wrap}}@media (max-width: 600px){.navbar-brand h1{display:none}.hero-stats{gap:20px}.species-grid,.stats-kpi-grid{grid-template-columns:1fr 1fr}}@media (max-width: 400px){.species-grid{grid-template-columns:1fr}}
