*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Hiragino Sans,Noto Sans JP,system-ui,sans-serif;background-color:#0f172a;color:#e2e8f0;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}body,#root{min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#1e293b;border-bottom:1px solid #334155;padding:16px 24px}.app-header h1{font-size:1.4rem;color:#f1f5f9;font-weight:700}.app-header p{color:#94a3b8;font-size:.875rem;margin-top:2px}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:300px;min-width:280px;background:#1e293b;border-right:1px solid #334155;overflow-y:auto;padding:12px;flex-shrink:0}.main-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.input-form{display:flex;flex-direction:column;gap:8px}.section{border:1px solid #334155;border-radius:8px;overflow:hidden}.section-toggle{width:100%;background:#0f172a;color:#94a3b8;border:none;padding:8px 12px;text-align:left;font-size:.8rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px}.section-toggle:hover{background:#1e293b;color:#e2e8f0}.section-body{padding:10px;display:flex;flex-direction:column;gap:6px}.field{display:flex;flex-direction:column;gap:2px}.field label{font-size:.75rem;color:#94a3b8}.field-input{display:flex;align-items:center;gap:4px}.field-input input{flex:1}.unit{font-size:.75rem;color:#64748b;white-space:nowrap}input[type=number],input[type=text],select{background:#0f172a;border:1px solid #334155;border-radius:4px;color:#e2e8f0;padding:4px 8px;font-size:.8rem;width:100%;font-family:inherit}input[type=number]:focus,select:focus{outline:none;border-color:#38bdf8}select{cursor:pointer}.child-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:8px;background:#0f172a;border-radius:6px;border:1px solid #334155}.child-label{font-size:.75rem;color:#94a3b8;min-width:30px}.field-inline{display:flex;flex-direction:column;gap:2px;flex:1;min-width:80px}.field-inline--wide{flex:2;min-width:150px}.field-inline label{font-size:.7rem;color:#64748b}.field-inline input,.field-inline select{width:100%}.field-input-inline{display:flex;align-items:center;gap:4px}.field-input-inline input{flex:1;min-width:0}.field-input-inline .unit{font-size:.75rem;color:#94a3b8;white-space:nowrap}.btn-add{background:#0f172a;border:1px dashed #334155;color:#64748b;padding:6px 10px;border-radius:6px;font-size:.8rem;cursor:pointer;width:100%}.btn-add:hover{border-color:#38bdf8;color:#38bdf8}.btn-remove{background:transparent;border:1px solid #7f1d1d;color:#f87171;padding:2px 8px;border-radius:4px;font-size:.75rem;cursor:pointer}.btn-remove:hover{background:#7f1d1d}.summary-panel{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:16px}.summary-panel h2{font-size:1rem;color:#f1f5f9;margin-bottom:12px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.summary-card{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:10px 12px}.summary-label{font-size:.75rem;color:#64748b;margin-bottom:4px}.summary-value{font-size:1.05rem;font-weight:700}.warning-banner{margin-top:12px;background:#450a0a;border:1px solid #7f1d1d;border-radius:6px;padding:10px 14px;color:#fca5a5;font-size:.85rem}.charts-area{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 900px){.charts-area{grid-template-columns:1fr}}.chart-card{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:16px}.chart-card h3{font-size:.9rem;color:#94a3b8;margin-bottom:12px}.tooltip{background:#1e293b;border:1px solid #475569;border-radius:6px;padding:8px 12px;font-size:.8rem}.tooltip-label{color:#94a3b8;margin-bottom:4px;font-weight:600}.timeline{display:flex;flex-direction:column;gap:8px}.timeline-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#0f172a;border-radius:6px;border-left:3px solid #38bdf8}.timeline-year{font-weight:700;color:#38bdf8;min-width:60px}.timeline-ages{font-size:.75rem;color:#64748b;min-width:100px}.timeline-events{display:flex;flex-wrap:wrap;gap:4px}.timeline-tag{background:#1e3a5f;border:1px solid #38bdf8;color:#7dd3fc;padding:2px 8px;border-radius:12px;font-size:.75rem}.export-row{display:flex;gap:10px;align-items:center}.btn-export{background:#0c4a6e;border:1px solid #38bdf8;color:#7dd3fc;padding:8px 16px;border-radius:6px;font-size:.85rem;cursor:pointer;font-family:inherit;font-weight:600}.btn-export:hover{background:#075985}.btn-secondary{background:#1e293b;border:1px solid #475569;color:#94a3b8;padding:8px 16px;border-radius:6px;font-size:.85rem;cursor:pointer;font-family:inherit}.btn-secondary:hover{border-color:#94a3b8;color:#e2e8f0}.table-wrapper{overflow-x:auto;border:1px solid #334155;border-radius:8px;grid-column:1 / -1}.data-table{width:100%;border-collapse:collapse;font-size:.78rem}.data-table th{background:#1e293b;color:#64748b;padding:6px 10px;text-align:right;border-bottom:1px solid #334155;white-space:nowrap}.data-table th:first-child,.data-table td:first-child{text-align:left}.data-table td{padding:5px 10px;text-align:right;border-bottom:1px solid #1e293b;color:#cbd5e1}.data-table tr:hover td{background:#1e293b}.row-negative td{background:#1c0e0e}.negative{color:#f87171!important}.positive{color:#34d399}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0f172a}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.tab-nav{display:flex;gap:4px;border-bottom:1px solid #334155;padding-bottom:0}.tab-btn{background:transparent;border:none;border-bottom:2px solid transparent;color:#64748b;padding:6px 14px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:6px;font-family:inherit;border-radius:0;transition:color .15s;margin-bottom:-1px}.tab-btn:hover{color:#e2e8f0}.tab-btn.active{color:#38bdf8;border-bottom-color:#38bdf8;font-weight:600}.tab-icon{font-size:1rem}.pension-person{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:10px;margin-bottom:8px}.person-title{font-size:.8rem;font-weight:700;color:#94a3b8;margin-bottom:8px}.subsection-label{font-size:.72rem;color:#475569;font-weight:600;margin:6px 0 3px;text-transform:uppercase;letter-spacing:.04em}.pension-breakdown{display:flex;flex-direction:column;gap:0}.breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:.82rem;border-bottom:1px solid #1e293b;color:#94a3b8}.breakdown-row:last-child{border-bottom:none}.total-row{font-weight:700;color:#e2e8f0}.summary-sub{font-size:.75rem;color:#64748b;margin-top:2px}.salary-presets{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0 8px}.preset-btn{background:#0f172a;border:1px solid #334155;color:#64748b;padding:3px 7px;border-radius:4px;font-size:.72rem;cursor:pointer;font-family:inherit}.preset-btn:hover{border-color:#38bdf8;color:#38bdf8}.preset-btn.active{background:#0c4a6e;border-color:#38bdf8;color:#7dd3fc;font-weight:600}.field-note{color:#475569;font-weight:400;font-size:.72rem}.takehome-preview{display:flex;justify-content:space-between;align-items:center;background:#0c2a1a;border:1px solid #166534;border-radius:5px;padding:5px 8px;margin:-2px 0 2px}.takehome-label{font-size:.72rem;color:#4ade80}.takehome-value{font-size:.82rem;font-weight:700;color:#34d399}.takehome-monthly{font-size:.72rem;font-weight:400;color:#6ee7b7;margin-left:4px}.app-header{padding-bottom:0}.pension-info-card{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:16px}.pension-info-title{font-size:.95rem;font-weight:700;color:#f1f5f9;margin-bottom:4px}.pension-info-section{border-left:3px solid #38bdf8;padding-left:12px}.pension-info-section h4{font-size:.82rem;font-weight:700;color:#7dd3fc;margin-bottom:6px}.pension-info-section p{font-size:.8rem;color:#94a3b8;line-height:1.6;margin-bottom:8px}.pension-info-section strong{color:#e2e8f0}.pension-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.pension-link{display:inline-block;background:#0c4a6e;border:1px solid #38bdf8;color:#7dd3fc;padding:4px 10px;border-radius:4px;font-size:.78rem;text-decoration:none}.pension-link:hover{background:#075985;color:#bae6fd}.pension-link-inline{color:#38bdf8;text-decoration:underline}.pension-link-inline:hover{color:#7dd3fc}.pension-formula{background:#0f172a;border:1px solid #334155;border-radius:6px;padding:10px 14px;margin-top:4px}.formula-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;font-size:.8rem;margin-bottom:6px}.formula-label{color:#94a3b8;white-space:nowrap}.formula-eq{color:#475569}.formula-body{color:#e2e8f0}.formula-example{font-size:.78rem;color:#64748b;padding-top:6px;border-top:1px solid #1e293b}.formula-example strong{color:#34d399}.pension-info-note{padding-top:12px;border-top:1px solid #334155}.pension-info-note p{font-size:.75rem;color:#475569;line-height:1.6}.edu-note{margin-top:8px}.edu-note-toggle{width:100%;background:transparent;border:1px dashed #334155;color:#64748b;padding:5px 8px;border-radius:4px;font-size:.75rem;cursor:pointer;text-align:left;font-family:inherit}.edu-note-toggle:hover{border-color:#94a3b8;color:#94a3b8}.edu-note-body{margin-top:6px;padding:10px;background:#0f172a;border:1px solid #334155;border-radius:6px}.edu-note-section-title{font-size:.75rem;font-weight:700;color:#94a3b8;margin-bottom:4px}.edu-note-desc{font-size:.72rem;color:#64748b;line-height:1.6;margin-bottom:8px}.edu-cost-table{width:100%;border-collapse:collapse;font-size:.72rem}.edu-cost-table th{background:#1e293b;color:#64748b;padding:4px 6px;text-align:right;border-bottom:1px solid #334155}.edu-cost-table th:first-child,.edu-cost-table th:nth-child(2){text-align:left}.edu-cost-table td{padding:4px 6px;text-align:right;color:#94a3b8;border-bottom:1px solid #1e293b}.edu-cost-table td:first-child,.edu-cost-table td:nth-child(2){text-align:left}.edu-total-row td{font-weight:700;color:#e2e8f0;border-top:1px solid #334155;border-bottom:none}.pension-form-note{font-size:.75rem;color:#64748b;line-height:1.6;margin-bottom:8px;padding:6px 8px;background:#0f172a;border-radius:4px;border-left:2px solid #38bdf8}.pension-total-banner{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding:14px 16px;background:#0f172a;border:1px solid #854d0e;border-radius:8px}.ref-page{max-width:860px;margin:0 auto;padding:24px 16px 48px;overflow-y:auto;flex:1}.ref-section{margin-bottom:40px}.ref-h2{font-size:1.15rem;font-weight:800;color:#f1f5f9;border-left:4px solid #38bdf8;padding-left:10px;margin-bottom:6px}.ref-source{font-size:.75rem;color:#64748b;margin-bottom:12px}.ref-card{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:14px 16px;margin-bottom:12px}.ref-h3{font-size:.9rem;font-weight:700;color:#e2e8f0;margin-bottom:8px}.ref-note{font-size:.75rem;color:#64748b;line-height:1.6}.ref-formula{background:#0f172a;border-left:3px solid #38bdf8;border-radius:4px;padding:10px 14px;font-size:.82rem;color:#cbd5e1;line-height:1.9;font-family:Hiragino Sans,monospace}.ref-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-top:4px}.ref-table th{background:#0f172a;color:#94a3b8;font-weight:600;padding:5px 8px;text-align:left;border-bottom:1px solid #334155}.ref-table td{padding:5px 8px;border-bottom:1px solid #1e293b;color:#cbd5e1}.ref-table tr:last-child td{border-bottom:none}.ref-total-row td{font-weight:700;color:#e2e8f0;border-top:1px solid #334155}.ref-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.ref-link{font-size:.78rem;color:#38bdf8;text-decoration:none;background:#0f172a;padding:3px 10px;border-radius:4px;border:1px solid #334155}.ref-link:hover{color:#7dd3fc;border-color:#38bdf8}.ref-link-inline{color:#38bdf8;text-decoration:none;margin-left:4px}.ref-link-inline:hover{color:#7dd3fc}.ref-link-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px}.ref-link-list a{font-size:.82rem;color:#38bdf8;text-decoration:none}.ref-link-list a:hover{color:#7dd3fc;text-decoration:underline}.mortgage-section{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:16px}.mortgage-title{font-size:1rem;font-weight:700;color:#f1f5f9;margin-bottom:12px}.mortgage-summary{display:flex;flex-wrap:wrap;gap:8px 24px;margin-bottom:4px}.mortgage-kv{display:flex;flex-direction:column;gap:2px}.mortgage-k{font-size:.72rem;color:#64748b}.mortgage-v{font-size:1rem;font-weight:700;color:#e2e8f0}.mortgage-v.highlight{color:#38bdf8}.mortgage-v.warn,.data-table td.warn{color:#f87171}.extra-expense-row{display:flex;flex-wrap:wrap;gap:6px;align-items:flex-end;padding:8px 0;border-bottom:1px solid #1e293b}.extra-expense-row:last-of-type{border-bottom:none}.extra-label-field{flex:1;min-width:80px}.extra-label-field input{width:100%}.invest-section-title{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}.invest-info-note{font-size:.78rem;color:#64748b;margin:2px 0 0}.invest-warn{color:#fbbf24;font-size:.78rem;background:#451a03;border:1px solid #92400e;border-radius:4px;padding:6px 10px}.app-footer{background:#1e293b;border-top:1px solid #334155;padding:10px 24px;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.78rem;color:#64748b;flex-shrink:0}.footer-disclaimer{font-size:.72rem;color:#64748b;line-height:1.6;text-align:center;max-width:880px}.footer-row{display:flex;align-items:center;gap:12px}.footer-sep{color:#334155}.footer-link{background:none;border:none;color:#38bdf8;font-size:.78rem;cursor:pointer;padding:0;text-decoration:underline}.footer-link:hover{color:#7dd3fc}.privacy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.privacy-modal{background:#1e293b;border:1px solid #334155;border-radius:10px;width:100%;max-width:680px;max-height:85vh;display:flex;flex-direction:column}.privacy-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #334155;flex-shrink:0}.privacy-header h2{font-size:1rem;color:#f1f5f9}.privacy-close{background:none;border:none;color:#94a3b8;font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:4px}.privacy-close:hover{background:#334155;color:#e2e8f0}.privacy-body{overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.privacy-updated{font-size:.78rem;color:#64748b}.privacy-section h3{font-size:.9rem;color:#38bdf8;margin-bottom:8px}.privacy-section p{font-size:.85rem;color:#cbd5e1;line-height:1.7;margin-bottom:6px}.privacy-section ul{font-size:.85rem;color:#cbd5e1;line-height:1.7;padding-left:20px;display:flex;flex-direction:column;gap:4px}.privacy-section a{color:#38bdf8;text-decoration:underline}.privacy-section a:hover{color:#7dd3fc}
