*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Hiragino Kaku Gothic ProN,Noto Sans JP,-apple-system,BlinkMacSystemFont,sans-serif;background:#eeeae4;color:#0d1f3c;-webkit-font-smoothing:antialiased}button{font-family:inherit}@keyframes fadeSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-slide{animation:fadeSlide .3s ease}.app-root{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;max-width:720px;width:100%;margin:0 auto;padding:24px 16px 56px}.top-bar{background:#0d1f3c;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #00000026}.top-bar-inner{max-width:1200px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.logo-area{cursor:pointer}.logo-brand{color:#c8923a;font-size:10px;letter-spacing:3px;font-weight:700}.logo-title{color:#fff;font-weight:800;font-size:15px}.top-bar-right{display:flex;gap:8px;align-items:center}.step-indicator{background:#ffffff1f;border-radius:8px;padding:5px 12px;font-size:12px;color:#fffc}.top-btn{background:#ffffff26;border:none;border-radius:8px;padding:6px 14px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;transition:background .2s}.top-btn:hover{background:#ffffff40}.top-btn.active{background:#c8923a}.user-btn{width:32px;height:32px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;background:#c8923a}.user-menu-wrapper{position:relative}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.user-menu{position:absolute;right:0;top:42px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;min-width:200px;z-index:100;overflow:hidden}.user-menu-header{padding:14px 16px;border-bottom:1px solid #E2E8F0}.user-menu-name{font-weight:700;color:#0d1f3c;font-size:14px}.user-menu-email{font-size:12px;color:#5a6a7e;margin-top:2px}.user-menu-item{display:block;width:100%;padding:12px 16px;border:none;background:none;text-align:left;font-size:13px;cursor:pointer;color:#0d1f3c;transition:background .15s}.user-menu-item:hover{background:#f8fafc}.user-menu-item.danger{color:#d94f4f}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d1f3c,#163358);padding:16px}.login-card{background:#fff;border-radius:24px;padding:40px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-brand{color:#c8923a;font-size:11px;letter-spacing:4px;font-weight:700;margin-bottom:8px}.login-title{font-size:22px;font-weight:800;color:#0d1f3c;margin-bottom:6px}.login-subtitle{font-size:13px;color:#5a6a7e}.login-form{display:flex;flex-direction:column;gap:16px}.login-error{background:#fef2f2;border:1px solid #FCA5A5;border-radius:10px;padding:10px 14px;font-size:13px;color:#d94f4f;font-weight:600}.login-button{width:100%;padding:16px;background:linear-gradient(135deg,#1e4d8c,#0d1f3c);border:none;border-radius:14px;color:#fff;font-weight:800;font-size:16px;cursor:pointer;transition:opacity .2s;margin-top:8px}.login-button:hover{opacity:.9}.login-button:disabled{opacity:.6;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:700;color:#0d1f3c}.form-input{width:100%;padding:14px 16px;border:2px solid #E2E8F0;border-radius:12px;font-size:15px;font-weight:600;color:#0d1f3c;outline:none;background:#fff;transition:border-color .2s}.form-input:focus{border-color:#1e4d8c}.form-input::placeholder{color:#94a3b8;font-weight:400}.btn{padding:14px 20px;border:none;border-radius:14px;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s;text-align:center}.btn-primary{background:linear-gradient(135deg,#1e4d8c,#0d1f3c);color:#fff;box-shadow:0 4px 16px #0d1f3c40}.btn-primary:hover{opacity:.9}.btn-primary.disabled,.btn-primary:disabled{background:#cbd5e0;box-shadow:none;cursor:not-allowed}.btn-gold{background:#c8923a;color:#fff;box-shadow:0 4px 16px #c8923a59}.btn-gold:hover{opacity:.9}.btn-outline{background:#fff;border:2px solid #0D1F3C;color:#0d1f3c}.btn-outline:hover{background:#f8fafc}.full-width{width:100%}.flex-1{flex:1}.home-container{max-width:560px;margin:0 auto}.hero{background:linear-gradient(135deg,#0d1f3c,#163358);border-radius:24px;padding:40px 32px;text-align:center;color:#fff;margin-bottom:20px}.hero-icon{font-size:40px;margin-bottom:12px}.hero-title{font-size:24px;font-weight:800;font-family:Georgia,serif;margin-bottom:8px}.hero-desc{font-size:14px;opacity:.8;line-height:1.7;margin-bottom:28px}.hero-btn{width:100%;padding:18px;font-size:17px;font-weight:800;border-radius:16px}.card{background:#fff;border-radius:16px;padding:20px;border:1px solid #E2E8F0}.card-title{font-size:14px;font-weight:800;color:#0d1f3c;margin-bottom:4px}.question-card{background:#fff;border-radius:20px;padding:28px 22px;box-shadow:0 4px 24px #00000012;margin-bottom:18px}.question-label{font-size:18px;font-weight:800;color:#0d1f3c;margin-bottom:22px;line-height:1.5}.diagnosis-input{font-size:16px}.slider-value{text-align:center;font-size:52px;font-weight:800;color:#0d1f3c;font-family:Georgia,serif;margin:12px 0}.slider-unit{font-size:20px;font-weight:400;color:#5a6a7e}.slider-input{width:100%;accent-color:#1E4D8C;height:6px;cursor:pointer}.choice-grid{display:grid;gap:10px}.choice-grid.one-col{grid-template-columns:1fr}.choice-grid.two-col{grid-template-columns:1fr 1fr}.choice-button{padding:14px 18px;border:2px solid #E2E8F0;border-radius:12px;background:#fff;color:#0d1f3c;cursor:pointer;font-weight:600;font-size:14px;text-align:left;transition:all .2s}.choice-button:hover{border-color:#94a3b8}.choice-button.selected{border-color:#1e4d8c;background:#0d1f3c;color:#fff;box-shadow:0 4px 12px #0d1f3c33}.choice-button.multi{padding:12px 14px;font-size:13px}.nav-buttons{display:flex;gap:10px}.result-header{background:linear-gradient(135deg,#0d1f3c,#163358);border-radius:20px;padding:24px;margin-bottom:18px;color:#fff}.result-name{font-size:20px;font-weight:800;font-family:Georgia,serif}.result-tags{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.result-tag{background:#ffffff21;border-radius:8px;padding:5px 12px;font-size:12px}.back-button{background:#ffffff26;border:none;color:#fff;border-radius:8px;padding:5px 12px;font-size:12px;cursor:pointer;margin-bottom:12px}.back-button:hover{background:#ffffff40}.tab-bar{overflow-x:auto;margin-bottom:16px;-webkit-overflow-scrolling:touch}.tab-bar-inner{display:flex;gap:3px;background:#f1f5f9;border-radius:12px;padding:4px;min-width:max-content}.tab-button{padding:9px 12px;border:none;border-radius:9px;cursor:pointer;white-space:nowrap;background:transparent;color:#5a6a7e;font-weight:400;font-size:12px;transition:all .2s}.tab-button.active{background:#fff;color:#0d1f3c;font-weight:700;box-shadow:0 2px 8px #00000014}.result-actions{display:flex;gap:10px;margin-top:22px}.result-actions .btn{flex:1}.retire-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cf-legend{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.insurance-detail{display:flex;gap:8px}.badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px;color:#fff}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.dashboard-label{font-size:11px;color:#5a6a7e;letter-spacing:2px;font-weight:700}.dashboard-title{font-size:20px;font-weight:800;color:#0d1f3c}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stat-card{background:#fff;border-radius:14px;padding:14px 12px;border:1px solid;text-align:center}.search-bar{display:flex;gap:8px;margin-bottom:14px}.search-input{flex:1;padding:10px 14px;font-size:13px}.sort-select{padding:10px 12px;border:1px solid #E2E8F0;border-radius:10px;font-size:13px;background:#fff;color:#0d1f3c;cursor:pointer;outline:none}.record-list{display:flex;flex-direction:column;gap:10px}.record-card{background:#fff;border-radius:16px;padding:16px;border:1px solid;cursor:pointer;transition:box-shadow .2s;position:relative}.record-card:hover{box-shadow:0 4px 20px #0000001a}.score-mini{border-radius:12px;padding:10px 14px;text-align:center;min-width:60px;flex-shrink:0}.record-tags{display:flex;gap:6px;flex-wrap:wrap}.tag-pill{font-size:11px;background:#f1f5f9;color:#5a6a7e;padding:2px 8px;border-radius:99px}.delete-icon{position:absolute;top:12px;right:40px;background:none;border:none;color:#94a3b8;font-size:16px;cursor:pointer;padding:4px}.delete-icon:hover{color:#d94f4f}.delete-confirm{margin-top:12px;display:flex;gap:8px;align-items:center}.btn-sm{padding:6px 14px;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer}.btn-danger{background:#d94f4f;color:#fff}.btn-cancel{background:#f1f5f9;color:#5a6a7e}.empty-state{padding:48px 20px;text-align:center}.planner-form{margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.planner-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;flex-shrink:0}.planner-card{cursor:default!important}.planner-card:hover{box-shadow:none!important}.planner-filter{min-width:130px}.planner-name-tag{color:#1e4d8c;font-weight:600}.user-menu-role{font-size:11px;color:#c8923a;font-weight:700;margin-top:2px}.alert{border-radius:12px;padding:10px 16px;margin-bottom:16px;font-size:13px;font-weight:700}.alert-success{background:#ecfdf5;border:1px solid #6EE7B7;color:#17996b}.alert-error{background:#fef2f2;border:1px solid #FCA5A5;color:#d94f4f}@media print{.no-print{display:none!important}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}.top-bar{display:none!important}.main-content{max-width:100%;padding:0}}@media(min-width:768px){.main-content{padding:32px 24px 64px}.hero{padding:56px 48px}.hero-title{font-size:30px}.hero-desc{font-size:16px;max-width:440px;margin-left:auto;margin-right:auto}.question-card{padding:36px 32px}.question-label{font-size:20px}.choice-button{padding:16px 22px;font-size:15px}.result-header{padding:32px}.result-name{font-size:24px}.tab-button{padding:10px 16px;font-size:13px}.login-card{padding:48px 40px}.dashboard-title{font-size:24px}.insurance-detail{gap:12px}}@media(min-width:1024px){.main-content{max-width:800px;padding:40px 32px 80px}.top-bar-inner{padding:14px 32px}.logo-title{font-size:17px}.hero{padding:64px 56px}.hero-title{font-size:34px}.stats-grid{gap:16px}.stat-card{padding:20px 16px}.record-card{padding:20px}.choice-grid.two-col{grid-template-columns:1fr 1fr}.retire-grid{gap:16px}}@media(max-width:400px){.main-content{padding:16px 12px 48px}.hero{padding:28px 20px;border-radius:18px}.hero-title{font-size:20px}.hero-desc{font-size:13px}.question-card{padding:20px 16px;border-radius:16px}.question-label{font-size:16px;margin-bottom:16px}.choice-grid.two-col{grid-template-columns:1fr}.choice-button{padding:12px 14px;font-size:13px}.result-header{padding:18px 16px;border-radius:16px}.result-name{font-size:17px}.tab-button{padding:8px 10px;font-size:11px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:6px}.stat-card{padding:10px 6px}.stat-card div:nth-child(2){font-size:16px!important}.retire-grid,.cf-legend{grid-template-columns:1fr}.insurance-detail,.result-actions{flex-direction:column}.slider-value{font-size:40px}.login-card{padding:28px 20px}.form-row{grid-template-columns:1fr}.search-bar{flex-wrap:wrap}.planner-filter{flex:1;min-width:0}}@media(max-width:640px){.no-mobile{display:none}}
