*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;-webkit-font-smoothing:antialiased;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Apple SD Gothic Neo,Pretendard,Noto Sans KR,sans-serif;line-height:1.6}#root{min-height:100vh}.home-page{flex-direction:column;min-height:100vh;display:flex}.hero{color:#fff;text-align:center;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 60%,#0f4c81 100%);padding:80px 24px 60px}.hero-inner{max-width:680px;margin:0 auto}.hero-badge{letter-spacing:.04em;background:#ffffff1f;border:1px solid #ffffff40;border-radius:999px;margin-bottom:20px;padding:4px 16px;font-size:.85rem;font-weight:600;display:inline-block}.hero-title{word-break:keep-all;margin-bottom:12px;font-size:clamp(1.8rem,5vw,2.8rem);font-weight:800;line-height:1.25}.hero-sub{opacity:.85;margin-bottom:16px;font-size:clamp(1rem,2.5vw,1.3rem);font-weight:500}.hero-desc{opacity:.65;word-break:keep-all;font-size:.95rem}.calc-section{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:48px 24px}.calc-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (width<=640px){.calc-grid{grid-template-columns:1fr}}.calc-card{cursor:pointer;text-align:left;background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:10px;padding:28px 24px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;position:relative;overflow:hidden}.calc-card:before{content:"";background:var(--accent);height:4px;position:absolute;top:0;left:0;right:0}.calc-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.calc-icon{font-size:2.2rem;line-height:1}.calc-body{flex:1}.calc-title{color:#0f172a;margin-bottom:4px;font-size:1.2rem;font-weight:700}.calc-subtitle{color:var(--accent);margin-bottom:8px;font-size:.875rem;font-weight:600}.calc-desc{color:#64748b;white-space:pre-line;word-break:keep-all;font-size:.85rem}.calc-cta{color:var(--accent);margin-top:8px;font-size:.875rem;font-weight:600;display:inline-block}.home-footer{text-align:center;color:#94a3b8;padding:20px 24px 32px;font-size:.78rem}.page{flex-direction:column;min-height:100vh;display:flex}.page-header{color:#fff;align-items:flex-start;gap:20px;padding:24px 32px;display:flex}.page-header h1{margin-bottom:4px;font-size:1.4rem;font-weight:800}.page-header p{opacity:.8;word-break:keep-all;font-size:.875rem}.page-header.orange{background:linear-gradient(135deg,#c2410c,#f97316)}.page-header.blue{background:linear-gradient(135deg,#1d4ed8,#3b82f6)}.page-header.green{background:linear-gradient(135deg,#15803d,#22c55e)}.page-header.purple{background:linear-gradient(135deg,#7e22ce,#a855f7)}.back-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff2e;border:1px solid #ffffff59;border-radius:8px;flex-shrink:0;margin-top:2px;padding:6px 14px;font-size:.875rem;font-weight:600;transition:background .15s}.back-btn:hover{background:#ffffff47}.page-body{flex:1;align-items:flex-start;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:28px 24px;display:flex}@media (width<=860px){.page-body{flex-direction:column}}.input-panel{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;flex-shrink:0;gap:4px;width:280px;padding:20px;display:flex}@media (width<=860px){.input-panel{width:100%}}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:8px;font-size:.8rem;font-weight:700}.slider-group{border-bottom:1px solid #f1f5f9;margin-bottom:16px;padding-bottom:16px}.slider-group:last-of-type{border-bottom:none}.slider-label-row{justify-content:space-between;align-items:baseline;margin-bottom:2px;display:flex}.slider-label-row label{color:#374151;font-size:.875rem;font-weight:600}.slider-value{color:#0f172a;font-size:.95rem;font-weight:700}.slider-desc{color:#94a3b8;word-break:keep-all;margin-bottom:6px;font-size:.75rem}.range-slider{appearance:none;cursor:pointer;background:#e2e8f0;border-radius:999px;outline:none;width:100%;height:4px;margin:4px 0}.range-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#3b82f6;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 4px #3b82f666}.slider-minmax{color:#cbd5e1;justify-content:space-between;margin-bottom:6px;font-size:.7rem;display:flex}.number-field{color:#0f172a;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:6px 10px;font-size:.875rem;font-weight:600;transition:border-color .15s}.number-field:focus{border-color:#3b82f6}.fire-target-box{text-align:center;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;margin-top:16px;padding:14px}.fire-target-label{color:#9a3412;margin-bottom:4px;font-size:.78rem;font-weight:600}.fire-target-amount{color:#c2410c;margin-bottom:2px;font-size:1.5rem;font-weight:800}.fire-target-formula{color:#ea580c;opacity:.8;font-size:.72rem}.result-panel{flex-direction:column;flex:1;gap:20px;min-width:0;display:flex}.fire-banner{border-radius:14px;align-items:center;gap:16px;padding:18px 22px;display:flex}.fire-banner.achieved{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid #f97316}.fire-banner.not-achieved{background:#f8fafc;border:2px solid #e2e8f0}.fire-banner-icon{font-size:2rem}.fire-banner-main{color:#c2410c;font-size:1.2rem;font-weight:800}.fire-banner.not-achieved .fire-banner-main{color:#64748b}.fire-banner-sub{color:#9a3412;margin-top:2px;font-size:.875rem}.fire-banner.not-achieved .fire-banner-sub{color:#94a3b8}.chart-box{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px 24px}.chart-box h3{color:#374151;margin-bottom:12px;font-size:.95rem;font-weight:700}.chart-note{color:#94a3b8;margin-top:-8px;margin-bottom:10px;font-size:.78rem}.chart-tooltip{color:#f1f5f9;background:#0f172aeb;border-radius:8px;padding:10px 14px;font-size:.82rem;box-shadow:0 4px 16px #0003}.tooltip-label{color:#cbd5e1;margin-bottom:4px;font-weight:700}.table-box{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px 24px}.table-box h3{color:#374151;margin-bottom:12px;font-size:.95rem;font-weight:700}.table-scroll{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px 14px;font-size:.78rem;font-weight:700}.data-table td{color:#374151;border-bottom:1px solid #f1f5f9;padding:10px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr.row-fire{background:#fff7ed;font-weight:700}.data-table tr.row-achieved{background:#f0fdf4}.td-year{color:#0f172a;font-weight:600}.td-num{font-feature-settings:"tnum";color:#1e293b;font-weight:600}.td-ratio{align-items:center;gap:8px;display:flex}.ratio-bar-wrap{background:#f1f5f9;border-radius:999px;flex:1;min-width:60px;height:6px;overflow:hidden}.ratio-bar{background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:999px;height:100%;transition:width .3s}.fire-tag{font-size:.9rem}.scenario-legend{flex-direction:column;gap:6px;display:flex}.legend-item{align-items:center;gap:8px;font-size:.82rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-label{color:#374151;min-width:50px;font-weight:600}.legend-fire{color:#64748b;font-size:.78rem}.badge-fire{color:#c2410c;white-space:nowrap;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;padding:2px 8px;font-size:.78rem;font-weight:700;display:inline-block}.badge-no{color:#94a3b8;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:2px 8px;font-size:.78rem;font-weight:600;display:inline-block}.dot-label{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.insight-box{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:1.5px solid #d8b4fe;border-radius:14px;padding:18px 22px}.insight-box h3{color:#7e22ce;margin-bottom:8px;font-size:.95rem;font-weight:700}.insight-box p{color:#6b21a8;word-break:keep-all;font-size:.875rem;line-height:1.7}
