:root{font-family:Hiragino Sans,Yu Gothic,Noto Sans JP,system-ui,sans-serif;color:#243142;background:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-width:320px;min-height:100vh}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:#243142;background:radial-gradient(circle at top left,rgba(255,231,239,.9),transparent 30rem),linear-gradient(180deg,#fffdfd,#f6fbff 48%,#fff)}button,input{font:inherit}button{border:0}a{color:inherit}.site-shell{min-height:100vh}.site-header{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand,.site-nav,.hero-actions,.hero-points{display:flex;align-items:center}.brand{gap:10px;font-weight:800;text-decoration:none;letter-spacing:0}.brand-mark{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;color:#fff;background:#e8507f;box-shadow:0 10px 24px #e8507f38}.brand-heart{display:inline-block;transform:scaleX(1.18);transform-origin:center}.site-nav{gap:6px;font-size:.9rem;color:#536275}.site-nav a{border-radius:999px;padding:8px 12px;text-decoration:none;font-weight:700}.site-nav a:hover{background:#ffffffb8;color:#d63b6d}.hero,.section,.generator-section{width:min(1120px,calc(100% - 32px));margin:0 auto}.hero{min-height:480px;padding:36px 0 32px;display:grid;grid-template-columns:minmax(0,1.02fr) minmax(340px,.98fr);align-items:center;gap:42px}.hero-copy h1,.section-heading h2,.page-header h2{margin:0;color:#1d2a3b;letter-spacing:0}.hero-copy h1{max-width:620px;font-size:clamp(1.6rem,2.6vw,2.4rem);line-height:1.3}.eyebrow{margin:0 0 10px;color:#d63b6d;font-size:1rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.hero-lead{max-width:590px;margin:14px 0 0;color:#536275;font-size:1rem;line-height:1.8}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:28px}.primary-link,.secondary-link{display:inline-flex;align-items:center;justify-content:center;min-height:48px;border-radius:14px;padding:0 20px;font-weight:800;text-decoration:none}.primary-link{color:#fff;background:#e8507f;box-shadow:0 14px 32px #e8507f40}.primary-link:hover{background:#d63b6d}.secondary-link{color:#9f3158;background:#fff0e7;border:1px solid #ffd3bd;box-shadow:0 10px 24px #e87b501f}.secondary-link:hover{color:#842646;background:#ffe4d5;border-color:#ffbd9a}.hero-points{flex-wrap:wrap;gap:8px;margin-top:22px}.hero-points span{color:#2f8f68;background:#ffffff7a;border:1.5px solid #43b883;border-radius:999px;padding:7px 12px;font-size:.84rem;font-weight:700}.hero-art{display:flex;justify-content:center}.hero-illustration{width:min(100%,520px);height:auto;filter:drop-shadow(0 24px 44px rgba(67,83,103,.15))}.section{padding:74px 0 0}.section-heading{max-width:720px;margin-bottom:24px}.section-heading h2,.page-header h2{font-size:clamp(1.65rem,3vw,2.35rem);line-height:1.28}.benefit-grid,.steps{display:grid;gap:16px}.benefit-grid{grid-template-columns:repeat(3,1fr)}.info-card,.step-card,.generator-card,.result-card{background:#ffffffe6;border:1px solid #e5edf5;box-shadow:0 16px 40px #43536714}.info-card,.step-card{border-radius:8px;padding:22px}.info-card h3,.step-card h3{margin:14px 0 8px;color:#1d2a3b;font-size:1.05rem}.info-card p,.step-card p{margin:0;color:#5f6f83;font-size:.92rem;line-height:1.75}.step-number{display:grid;place-items:center;font-weight:800}.card-icon{width:54px;height:54px;display:block;object-fit:contain}.steps{grid-template-columns:repeat(4,1fr)}.step-number{width:34px;height:34px;border-radius:50%;color:#fff;background:#43b883}.generator-section{padding:78px 0 86px}.generator-card{max-width:760px;margin:0 auto;border-radius:8px;padding:clamp(22px,5vw,44px)}.page,.page-header{max-width:760px;margin:0 auto}.page{padding:32px 16px 72px}.page-header{text-align:center;margin-bottom:24px}.page-header h1{margin:0 0 8px;color:#1d2a3b;font-size:clamp(1.8rem,4vw,2.5rem);line-height:1.2}.page-subtitle{margin:10px auto 0;max-width:580px;color:#5f6f83;font-size:.95rem;line-height:1.75}.notice{background:#fff8e1;border:1px solid #ffe082;border-radius:8px;padding:12px 16px;color:#5d4037;font-size:.84rem;line-height:1.7;margin-bottom:24px}.form-section{display:flex;flex-direction:column;gap:28px}.uploader-label{display:block;margin-bottom:7px;color:#1d2a3b;font-weight:800}.uploader-hint{margin:0 0 10px;color:#728197;font-size:.84rem;line-height:1.6}.upload-area{border:2px dashed #c8d7e7;border-radius:8px;padding:26px 18px;text-align:center;cursor:pointer;display:flex;flex-direction:column;gap:4px;color:#536275;background:#f8fbff;transition:border-color .2s,background .2s,color .2s}.upload-area:hover{border-color:#e8507f;background:#fff7fa;color:#d63b6d}.upload-limit{color:#8a98aa;font-size:.8rem}.preview-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.preview-item{position:relative;width:82px}.preview-item img{width:82px;height:82px;object-fit:cover;border:1px solid #dce7f2;border-radius:8px}.preview-name{display:block;color:#5f6f83;font-size:.75rem;text-align:center}.remove-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;padding:0;color:#fff;background:#1d2a3bad;cursor:pointer;font-size:.7rem}.tone-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.tone-option{display:flex;flex-direction:column;min-height:82px;border:2px solid #e5edf5;border-radius:8px;padding:13px 14px;cursor:pointer;background:#fff;transition:border-color .2s,background .2s,transform .2s}.tone-option:hover{transform:translateY(-1px)}.tone-option input{display:none}.tone-option.selected{border-color:#e8507f;background:#fff1f6}.tone-name{color:#1d2a3b;font-size:.95rem;font-weight:800}.tone-desc{color:#728197;font-size:.78rem;line-height:1.6}.pay-btn,.reset-btn,.copy-btn{cursor:pointer;font-weight:800}.pay-btn{width:100%;border-radius:12px;padding:16px;color:#fff;background:#e8507f;box-shadow:0 14px 30px #e8507f38;font-size:1.05rem;transition:background .2s,box-shadow .2s}.pay-btn:hover:not(:disabled){background:#d63b6d;box-shadow:0 18px 36px #e8507f47}.pay-btn:disabled{cursor:not-allowed;color:#f8fafc;background:#b8c3d1;box-shadow:none}.reset-btn{display:block;margin:32px auto 0;border:2px solid #e8507f;border-radius:12px;padding:12px 32px;color:#e8507f;background:#fff}.reset-btn:hover{background:#fff1f6}.payment-info{margin:0;color:#536275;text-align:center}.payment-form{display:flex;flex-direction:column;gap:16px}.error-msg{margin:0;border-radius:8px;padding:10px 12px;color:#b42318;background:#fff1f0;font-size:.88rem}.result-display{display:flex;flex-direction:column;gap:32px}.result-section h2{margin:0 0 12px;border-left:4px solid #e8507f;padding-left:10px;color:#1d2a3b;font-size:1.12rem}.ai-supplement-note{font-size:.8rem;color:#8a96a8;margin:-4px 0 12px;line-height:1.6}.result-card{border-radius:8px;padding:16px;margin-bottom:12px}.result-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;color:#728197;font-size:.85rem}.result-text{margin:0;color:#334155;font-size:.95rem;line-height:1.8;white-space:pre-wrap}.copy-btn{border-radius:8px;padding:6px 12px;color:#fff;background:#43b883;font-size:.8rem;white-space:nowrap}.copy-btn:hover{background:#349f70}.site-footer{border-top:1px solid #e5edf5;background:#ffffffbd}.site-footer-inner{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:30px 0;display:grid;grid-template-columns:minmax(260px,1fr) auto minmax(220px,.8fr);align-items:center;gap:24px}.footer-brand{display:flex;align-items:center;gap:12px}.footer-logo,.footer-copy,.footer-note p{margin:0}.footer-logo{color:#1d2a3b;font-weight:800}.footer-copy,.footer-note{color:#728197;font-size:.84rem;line-height:1.7}.footer-center{display:flex;flex-direction:column;align-items:center;gap:10px}.footer-privacy-note{margin:0;color:#728197;font-size:.84rem}.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;color:#536275;font-size:.88rem;font-weight:700}.footer-nav a{border-radius:999px;padding:7px 10px;text-decoration:none}.footer-nav a:hover{color:#d63b6d;background:#fff1f6}.footer-note{text-align:right}.footer-note .footer-copyright{margin:24px 0;color:#e8507f;text-align:center;font-weight:800}@media (max-width: 900px){.site-header{align-items:flex-start;flex-direction:column}.hero{min-height:auto;grid-template-columns:1fr;padding-top:34px}.hero-art{order:-1}.hero-illustration{max-width:420px}.benefit-grid,.steps{grid-template-columns:repeat(2,1fr)}.site-footer-inner{grid-template-columns:1fr;align-items:flex-start}.footer-center{align-items:center}.footer-nav,.footer-legal{justify-content:center}.footer-note .footer-copyright{margin-top:12px}.footer-note{text-align:left}}@media (max-width: 620px){.site-header,.hero,.section,.generator-section,.site-footer-inner{width:min(100% - 24px,1120px)}.site-nav{width:100%;overflow-x:auto;padding-bottom:2px}.site-nav a{white-space:nowrap}.hero{gap:24px;padding:24px 0 22px}.hero-copy h1{font-size:2.15rem}.hero-lead{font-size:.96rem}.primary-link,.secondary-link{width:100%}.section{padding-top:54px}.benefit-grid,.steps,.tone-options{grid-template-columns:1fr}.generator-section{padding:56px 0 64px}.generator-card{padding:22px 16px}.page{padding:24px 12px 56px}.upload-area{padding:22px 14px}}.mode-tabs{display:flex;gap:8px;margin-bottom:12px}.mode-tab{padding:6px 18px;border:1.5px solid #c8d7e7;border-radius:20px;background:#f8fbff;color:#536275;font-size:.9rem;cursor:pointer;transition:all .2s}.mode-tab.active{border-color:#2e6fcd;background:#2e6fcd;color:#fff;font-weight:700}.profile-textarea{width:100%;border:2px solid #c8d7e7;border-radius:8px;padding:14px;font-size:.95rem;line-height:1.7;color:#1d2a3b;background:#f8fbff;resize:vertical;box-sizing:border-box;transition:border-color .2s}.profile-textarea:focus{outline:none;border-color:#2e6fcd}.page h1{margin:0 0 4px;color:#1d2a3b;font-size:clamp(1.6rem,4vw,2.2rem)}.legal-date{margin:0 0 28px;color:#8a98aa;font-size:.85rem}.page h2{margin:32px 0 10px;color:#1d2a3b;font-size:1.05rem;border-left:3px solid #e8507f;padding-left:10px}.page p,.page li{color:#3d4f63;line-height:1.85;font-size:.95rem}.page ul{padding-left:1.4em;margin:8px 0}.page a{color:#2e6fcd;text-decoration:underline}.law-table{width:100%;border-collapse:collapse;margin-top:16px;font-size:.93rem}.law-table th,.law-table td{padding:13px 16px;border:1px solid #dce7f2;vertical-align:top;line-height:1.75}.law-table th{width:180px;background:#f4f8fc;color:#1d2a3b;font-weight:700;white-space:nowrap}.law-table td{color:#3d4f63}.footer-legal{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin:8px 0;font-size:.82rem}.footer-legal a{color:#8a98aa;text-decoration:none}.footer-legal a:hover{color:#d63b6d;text-decoration:underline}@media (max-width: 640px){.law-table th{width:120px;white-space:normal}}.plan-selector{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap}.plan-card{flex:1;min-width:140px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px 14px;border:2px solid #dce7f2;border-radius:12px;background:#fff;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s;position:relative}.plan-card:hover{border-color:#d63b6d}.plan-card.active{border-color:#d63b6d;background:#fff5f8;box-shadow:0 0 0 3px #d63b6d1f}.plan-badge{position:absolute;top:-10px;right:10px;background:#d63b6d;color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}.plan-name{font-size:.92rem;font-weight:700;color:#1d2a3b}.plan-price{font-size:1.3rem;font-weight:800;color:#d63b6d;margin:2px 0}.plan-desc{font-size:.78rem;color:#6b7a8d;line-height:1.5}.bundle-token-section{margin-bottom:24px;padding:18px 20px;background:#f4f8fc;border-radius:10px;border:1px solid #dce7f2}.bundle-token-label{font-size:.9rem;font-weight:600;color:#2e6fcd;margin-bottom:10px}.bundle-token-input{width:100%;box-sizing:border-box;padding:10px 14px;border:1.5px solid #b8ccdf;border-radius:8px;font-size:.9rem;font-family:monospace;background:#fff;color:#1d2a3b;outline:none;transition:border-color .15s}.bundle-token-input:focus{border-color:#2e6fcd}.bundle-token-hint{margin-top:8px;font-size:.82rem;color:#2e6fcd}.bundle-token-result{background:#fff9e6;border:1.5px solid #f5c842;border-radius:12px;padding:20px 24px}.bundle-token-desc{font-size:.88rem;color:#7a6000;margin-bottom:14px;line-height:1.65}.bundle-token-card{background:#fffdf0}.bundle-token-value{font-family:monospace;font-size:1rem;letter-spacing:.03em;word-break:break-all;color:#1d2a3b}.credits-remaining-badge{display:inline-block;margin-bottom:16px;padding:6px 16px;background:#f0f6ff;border:1px solid #b8ccdf;border-radius:20px;font-size:.88rem;color:#2e6fcd}@media (max-width: 640px){.plan-selector{flex-direction:column}.plan-card{min-width:unset}}
