@import "https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;600;700&family=DM+Mono:wght@400;500&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--c-bg:#f8f6f1;--c-surface:#fff;--c-text:#1a1714;--c-sub:#6b6560;--c-accent:#c8502a;--c-accent-light:#f3e9e4;--c-border:#e2ddd6;--c-line:#d4cfc8;--c-done:#3b7d5e;--font-serif:"Noto Serif JP", "Georgia", serif;--font-sans:"Zen Kaku Gothic New", sans-serif;--font-mono:"DM Mono", monospace;--radius:6px;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f}html{font-size:16px}body{background:var(--c-bg);color:var(--c-text);font-family:var(--font-sans);min-height:100vh;line-height:1.7}header{background:var(--c-text);color:#fff;z-index:100;border-bottom:3px solid var(--c-accent);padding:0 24px;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:860px;margin:0 auto;padding:14px 0;display:flex}.logo{align-items:center;gap:14px;display:flex}.logo-mark{font-family:var(--font-mono);background:var(--c-accent);color:#fff;letter-spacing:.08em;border-radius:3px;padding:5px 9px;font-size:13px;font-weight:500}.logo h1{font-family:var(--font-serif);color:#fff;letter-spacing:.02em;font-size:18px;font-weight:600}.logo .subtitle{color:#aaa49c;letter-spacing:.1em;font-size:11px;font-family:var(--font-mono)}.btn-back{font-family:var(--font-sans);color:#ccc;border-radius:var(--radius);cursor:pointer;background:0 0;border:1px solid #444;padding:6px 14px;font-size:13px;transition:all .2s}.btn-back:hover{color:#fff;border-color:#888}.step-indicator{border-top:1px solid #333;align-items:center;gap:0;max-width:860px;margin:0 auto;padding:10px 0;display:flex}.step{color:#666;font-size:12px;font-family:var(--font-mono);letter-spacing:.05em;white-space:nowrap;align-items:center;gap:8px;display:flex}.step span{color:#888;background:#444;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:500;display:flex}.step.active{color:#fff}.step.active span{background:var(--c-accent);color:#fff}.step.done{color:#5a9}.step.done span{background:var(--c-done);color:#fff}.step-line{background:#333;flex:1;height:1px;margin:0 12px}main{max-width:860px;margin:0 auto;padding:40px 24px 80px}.step-heading{margin-bottom:32px}.step-heading h2{font-family:var(--font-serif);letter-spacing:.02em;margin-bottom:6px;font-size:26px;font-weight:700}.step-heading p{color:var(--c-sub);font-size:14px}.selected-badge{color:var(--c-accent);background:var(--c-accent-light);border:1px solid #e8c4b4;border-radius:20px;align-items:center;gap:6px;margin-bottom:12px;padding:4px 12px;font-size:13px;font-weight:600;display:inline-flex}.type-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.type-card{background:var(--c-surface);border:1.5px solid var(--c-border);cursor:pointer;text-align:left;font-family:var(--font-sans);border-radius:8px;padding:24px 20px;transition:all .2s;position:relative;overflow:hidden}.type-card:before{content:"";background:var(--c-accent);transform-origin:bottom;width:3px;transition:transform .2s;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.type-card:hover{border-color:var(--c-accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.type-card:hover:before{transform:scaleY(1)}.type-icon{margin-bottom:10px;font-size:28px;display:block}.type-card strong{color:var(--c-text);margin-bottom:4px;font-size:15px;font-weight:700;line-height:1.4;display:block}.type-card p{color:var(--c-sub);font-size:12px;line-height:1.5}.form-panel{background:var(--c-surface);border:1.5px solid var(--c-border);box-shadow:var(--shadow);border-radius:10px;padding:36px 40px}.field{margin-bottom:22px}.field label{color:var(--c-text);letter-spacing:.02em;align-items:center;gap:6px;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.req{color:var(--c-accent);background:var(--c-accent-light);letter-spacing:.05em;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}input[type=text],input[type=date],select,textarea{width:100%;font-family:var(--font-sans);color:var(--c-text);border:1.5px solid var(--c-line);border-radius:var(--radius);background:#fdfcfb;outline:none;padding:10px 14px;font-size:14px;line-height:1.6;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--c-accent);background:#fff;box-shadow:0 0 0 3px #c8502a1f}textarea{resize:vertical}select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.form-actions{justify-content:flex-end;margin-top:32px;display:flex}.btn{font-family:var(--font-sans);border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;border:none;align-items:center;gap:8px;padding:11px 24px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--c-accent);color:#fff}.btn-primary:hover{background:#b04422;box-shadow:0 4px 14px #c8502a59}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--c-surface);color:var(--c-text);border:1.5px solid var(--c-border)}.btn-secondary:hover{border-color:var(--c-text)}.btn-icon{font-size:16px}.error-msg{color:#c0392b;border-radius:var(--radius);background:#fdf0ee;border:1px solid #eab5af;margin-top:14px;padding:10px 14px;font-size:13px}.hidden{display:none!important}.spinner-inline{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.result-toolbar{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.result-panel{background:var(--c-surface);border:1.5px solid var(--c-border);box-shadow:var(--shadow);border-radius:10px;overflow:hidden}.result-content{font-family:var(--font-serif);color:var(--c-text);padding:40px 48px;font-size:15px;line-height:2}.result-content h1{border-bottom:2px solid var(--c-text);font-size:22px;font-weight:700;line-height:1.5;font-family:var(--font-serif);margin-bottom:6px;padding-bottom:12px}.result-content h2{color:var(--c-accent);font-size:16px;font-weight:700;font-family:var(--font-sans);letter-spacing:.04em;text-transform:none;margin-top:28px;margin-bottom:8px}.result-content h3{color:var(--c-sub);font-size:14px;font-weight:700;font-family:var(--font-sans);margin-top:16px;margin-bottom:4px}.result-content p{margin-bottom:12px}.result-content strong{color:var(--c-text);font-weight:700}.result-content ul{margin-bottom:12px;padding-left:20px}.result-content li{margin-bottom:4px}.result-content hr{border:none;border-top:1px solid var(--c-border);margin:24px 0}@media (width<=640px){.form-panel,.result-content{padding:24px 20px}.type-grid{grid-template-columns:1fr 1fr}.step-heading h2{font-size:20px}.header-inner{flex-wrap:wrap;gap:8px}.step-indicator{overflow-x:auto}}.result-tabs{gap:4px;margin-bottom:12px;display:flex}.tab-btn{font-family:var(--font-sans);border-radius:var(--radius) var(--radius) 0 0;border:1.5px solid var(--c-border);background:var(--c-bg);color:var(--c-sub);cursor:pointer;border-bottom:none;padding:8px 20px;font-size:13px;font-weight:600;transition:all .15s}.tab-btn.active{background:var(--c-surface);color:var(--c-text);border-color:var(--c-border)}.progress-msg{color:var(--c-sub);border-radius:var(--radius);border:1px solid var(--c-line);background:#f5f3ee;margin-top:12px;padding:10px 14px;font-size:13px}.result-content table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--font-sans);margin:16px 0}.result-content td{border:1px solid var(--c-border);vertical-align:top;padding:8px 12px}.result-content tr:first-child td{background:#f5f3ee;font-weight:600}.btn-back{font-family:var(--font-sans);color:#fff;background:var(--c-accent);border-radius:var(--radius);cursor:pointer;letter-spacing:.03em;border:none;padding:8px 18px;font-size:13px;font-weight:700;transition:all .2s}.btn-back:hover{background:#b04422}.field-hint{color:var(--c-sub);font-size:11px;font-family:var(--font-mono);margin-top:4px}
