@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600&family=Noto+Serif+JP:wght@300;400;500&display=swap";:root{--color-bg:#fdf6f8;--color-card:#fff;--color-card-hover:#fef9fa;--color-text:#4a3040;--color-text-light:#6b4f60;--color-muted:#a08898;--color-border:#e8d5de;--color-accent:#d4899a;--color-accent-light:#e0a0b0;--color-accent-dark:#c07088;--color-accent-bg:#faf0f3;--font-serif:"Noto Serif JP", "Georgia", serif;--font-sans:"Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", sans-serif}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:15px;line-height:1.7}#root{min-height:100dvh}:focus-visible{outline:2px solid var(--color-accent-light);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::selection{background:var(--color-accent-bg);color:var(--color-text)}.app{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px 20px;display:flex;position:relative}.step-container{text-align:center;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;display:flex}.step-container.result{max-width:650px}.progress-bar{background:var(--color-border);z-index:100;height:3px;position:fixed;top:0;left:0;right:0}.progress-bar-fill{background:var(--color-accent);height:100%}.progress-bar-label{color:var(--color-muted);letter-spacing:.05em;font-size:12px;position:absolute;top:10px;right:16px}.welcome-brand{letter-spacing:.3em;color:var(--color-accent);text-transform:uppercase;margin:0 0 20px;font-size:11px;font-weight:300}.welcome-title{font-family:var(--font-serif);letter-spacing:.06em;color:var(--color-text);margin:0;font-size:24px;font-weight:400;line-height:1.7}.welcome-description{color:var(--color-text-light);flex-direction:column;gap:16px;font-size:14px;line-height:1.9;display:flex}.welcome-note{color:var(--color-muted);font-style:italic}.welcome-credit{color:var(--color-muted);letter-spacing:.1em;margin-top:8px;font-size:12px}.step-label{color:var(--color-accent);letter-spacing:.15em;text-transform:uppercase;margin:0;font-size:12px}.step-question{font-family:var(--font-serif);color:var(--color-text);overflow-wrap:break-word;margin:0;font-size:20px;font-weight:400;line-height:1.7}.step-hint{color:var(--color-muted);margin:-12px 0 0;font-size:13px}.select-options{flex-direction:column;gap:12px;width:100%;display:flex}.select-option{background:var(--color-card);border:1.5px solid var(--color-border);cursor:pointer;text-align:left;color:var(--color-text);border-radius:12px;align-items:center;gap:14px;width:100%;padding:16px 20px;font-size:14px;transition:all .2s;display:flex}.select-option:hover{border-color:var(--color-accent-light);background:var(--color-card-hover)}.select-option.selected{border-color:var(--color-accent);background:var(--color-accent-bg)}.select-option-label{background:var(--color-border);width:28px;height:28px;color:var(--color-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:all .2s;display:flex}.select-option.selected .select-option-label{background:var(--color-accent);color:#fff}.select-option-desc{line-height:1.5}.text-input{border:1.5px solid var(--color-border);background:var(--color-card);width:100%;font-size:15px;font-family:var(--font-sans);color:var(--color-text);border-radius:12px;outline:none;padding:14px 18px;transition:border-color .2s}.text-input:focus{border-color:var(--color-accent)}.text-area{border:1.5px solid var(--color-border);background:var(--color-card);width:100%;font-size:15px;font-family:var(--font-sans);color:var(--color-text);resize:vertical;border-radius:12px;outline:none;min-height:120px;padding:16px 18px;line-height:1.7;transition:border-color .2s}.text-area:focus{border-color:var(--color-accent)}.text-input::placeholder,.text-area::placeholder{color:var(--color-muted)}.btn-primary{background:linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));color:#fff;font-size:15px;font-family:var(--font-sans);letter-spacing:.06em;cursor:pointer;text-align:center;border:none;border-radius:100px;padding:14px 48px;text-decoration:none;transition:all .2s;display:inline-block}.btn-primary:hover{background:linear-gradient(135deg, var(--color-accent-dark), #a8607a);transform:translateY(-1px)}.btn-primary:disabled{background:var(--color-border);color:var(--color-muted);cursor:not-allowed;transform:none}.btn-secondary{color:var(--color-muted);border:1.5px solid var(--color-border);font-size:14px;font-family:var(--font-sans);letter-spacing:.04em;cursor:pointer;background:0 0;border-radius:100px;padding:12px 32px;transition:all .2s}.btn-secondary:hover{border-color:var(--color-accent-light);color:var(--color-text)}.btn-back{color:var(--color-muted);cursor:pointer;letter-spacing:.04em;background:0 0;border:none;padding:8px 16px;font-size:13px;transition:color .2s}.btn-back:hover{color:var(--color-text)}.loading{justify-content:center;min-height:60vh}.loading-visual{width:80px;height:80px;position:relative}.loading-pen-svg{width:80px;height:80px}.loading-messages{flex-direction:column;gap:8px;min-height:72px;display:flex}.loading-message{color:var(--color-muted);letter-spacing:.04em;font-size:14px}.letter-card{text-align:left;background:linear-gradient(168deg,#fffbfc 0%,#fef6f8 40%,#faf0f3 100%);border:none;border-radius:2px;width:100%;padding:52px 36px 44px;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000000f,0 8px 32px #0000000f,0 24px 60px #d4899a1f}.letter-card:before{content:"";pointer-events:none;border:1px solid #d4899a33;border-radius:1px;position:absolute;inset:10px}.letter-card:after{content:"";pointer-events:none;border:1px solid #d4899a1a;border-radius:1px;position:absolute;inset:14px}.letter-header{text-align:center;margin-bottom:36px}.letter-brand-mark{font-family:var(--font-serif);letter-spacing:.3em;color:var(--color-accent-light);text-transform:uppercase;margin:0 0 24px;font-size:11px;font-weight:300}.letter-ornament{color:var(--color-accent-light);justify-content:center;align-items:center;gap:16px;margin-bottom:28px;display:flex}.letter-ornament-line{background:linear-gradient(90deg, transparent, var(--color-accent-light), transparent);flex:1;max-width:80px;height:1px}.letter-ornament-heart{color:var(--color-accent-light);flex-shrink:0;font-size:14px;line-height:1}.letter-ornament-heart:before{content:"♥"}.letter-to{font-family:var(--font-serif);color:var(--color-text);text-align:left;margin:0;font-size:20px;font-weight:400}.letter-keywords{margin-bottom:32px}.letter-keywords-label{font-family:var(--font-serif);color:var(--color-accent-light);letter-spacing:.18em;margin:0 0 14px;font-size:11px;font-weight:300}.keywords-list{flex-wrap:wrap;gap:10px;display:flex}.keyword-tag{color:var(--color-accent-dark);letter-spacing:.06em;background:0 0;border:1px solid #d4899a59;border-radius:100px;padding:8px 20px;font-size:13px;font-weight:500;display:inline-block}.letter-catchcopy{text-align:center;margin-bottom:32px;padding:24px 0;position:relative}.letter-catchcopy:before,.letter-catchcopy:after{content:"";background:var(--color-accent-light);width:40px;height:1px;margin:0 auto;display:block}.letter-catchcopy:before{margin-bottom:24px}.letter-catchcopy:after{margin-top:24px}.catchcopy-text{font-family:var(--font-serif);color:var(--color-text);letter-spacing:.04em;margin:0;font-size:18px;line-height:1.7}.letter-body{margin-bottom:32px}.letter-body p{color:var(--color-text-light);text-align:justify;margin:0 0 18px;font-size:14px;line-height:2.1}.letter-body p:last-child{margin-bottom:0}.letter-actions{background:var(--color-accent-bg);border-radius:12px;margin-bottom:40px;padding:28px 24px}.letter-actions-label{font-family:var(--font-serif);color:var(--color-accent-dark);letter-spacing:.1em;text-align:center;margin:0 0 20px;font-size:13px;font-weight:400}.actions-list{flex-direction:column;gap:16px;display:flex}.action-item{align-items:flex-start;gap:14px;display:flex}.action-number{background:var(--color-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-top:2px;font-size:12px;font-weight:600;display:flex}.action-text{color:var(--color-text);text-align:left;margin:0;font-size:14px;line-height:1.7}.letter-footer{justify-content:space-between;align-items:flex-end;margin-top:8px;display:flex}.letter-signature p{font-family:var(--font-serif);color:var(--color-text);letter-spacing:.06em;margin:0;font-size:16px}.letter-seal{background:radial-gradient(circle at 40% 35%,#e0a0b0 0%,#d4899a 40%,#c07088 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex;box-shadow:inset 0 2px 4px #fff3,inset 0 -2px 4px #0000001a,0 2px 8px #c070884d}.letter-seal-text{font-family:var(--font-serif);color:#ffffffe6;letter-spacing:.05em;margin-top:-1px;font-size:18px;font-weight:500}.result-actions{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}.result-credit{color:var(--color-muted);letter-spacing:.08em;font-size:12px}.email-gate{text-align:center}.email-gate-header{margin-bottom:36px}.email-gate-brand{letter-spacing:.3em;color:var(--color-accent);text-transform:uppercase;margin:0 0 20px;font-size:11px;font-weight:300}.email-gate-title{font-family:var(--font-serif);color:var(--color-text);letter-spacing:.04em;margin:0 0 16px;font-size:20px;font-weight:400;line-height:1.8}.email-gate-desc{color:var(--color-text-light);margin:0;font-size:14px;line-height:2}.email-gate-form{flex-direction:column;gap:20px;width:100%;display:flex}.email-gate-field{text-align:left}.email-gate-name-row{gap:12px;display:flex}.email-gate-name-field{flex:1}.email-gate-label{color:var(--color-accent);letter-spacing:.08em;margin-bottom:8px;font-size:12px;font-weight:500;display:block}.email-gate-hint{color:var(--color-muted);margin:6px 0 0;font-size:12px;line-height:1.6}.email-gate-submit{width:100%;margin-top:8px}.email-gate-optin{color:var(--color-muted);text-align:left;margin:0;font-size:11px;line-height:1.8}.email-gate-optin a{color:var(--color-accent);text-decoration:underline}.seminar-banner{flex-direction:column;align-items:center;gap:28px;width:100%;margin-top:8px;display:flex}.seminar-banner-img{border-radius:12px;width:100%;max-width:480px;box-shadow:0 2px 8px #0000000f,0 8px 24px #00000014}.seminar-line{background:var(--color-card);border:1.5px solid var(--color-border);border-radius:12px;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:480px;padding:28px 24px;display:flex}.seminar-line-label{font-family:var(--font-serif);color:var(--color-text);letter-spacing:.04em;margin:0;font-size:15px;font-weight:400}.seminar-line-qr{width:160px;height:160px}.btn-line{color:#fff;font-size:15px;font-family:var(--font-sans);letter-spacing:.04em;text-align:center;background:#06c755;border:none;border-radius:100px;padding:14px 32px;font-weight:500;text-decoration:none;transition:background .2s,transform .2s;display:inline-block}.btn-line:hover{background:#05b54c;transform:translateY(-1px)}.email-sent-notice{color:var(--color-muted);text-align:center;letter-spacing:.04em;margin:0 0 8px;font-size:13px}.error-toast{z-index:200;background:#fff;border:1px solid #e8c4c4;border-radius:12px;align-items:center;gap:12px;max-width:90vw;padding:14px 20px;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000014}.error-toast p{color:#8b4545;margin:0;font-size:13px}.error-toast button{color:#8b4545;cursor:pointer;white-space:nowrap;background:0 0;border:none;font-size:12px}.admin-login{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.admin-login h1{color:var(--color-accent);letter-spacing:.14em;text-transform:uppercase;margin:0 0 8px;font-size:13px;font-weight:500}.admin-login-subtitle{color:var(--color-muted);letter-spacing:.04em;margin:0 0 32px;font-size:11px}.admin-login-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;width:100%;max-width:380px;padding:32px 28px 28px;box-shadow:0 2px 20px #00000008}.admin-login-form{flex-direction:column;gap:14px;width:100%;display:flex}.admin-login-tabs{background:var(--color-bg);border-radius:8px;gap:4px;margin-bottom:6px;padding:3px;display:flex}.admin-login-tabs button{font-size:12px;font-weight:500;font-family:var(--font-sans);color:var(--color-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 0;transition:all .2s}.admin-login-tabs button.active{color:var(--color-text);background:#fff;box-shadow:0 1px 3px #0000000f}.admin-login-tabs button:not(.active):hover{color:var(--color-text)}.admin-login-form input{border:1px solid var(--color-border);font-size:13px;font-family:var(--font-sans);color:var(--color-text);background:#fff;border-radius:10px;outline:none;padding:11px 14px;transition:border-color .2s,box-shadow .2s}.admin-login-form input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #d4899a1a}.admin-login-form input::placeholder{color:#c4b8bc;font-size:13px}.password-field{position:relative}.password-field input{width:100%;padding-right:44px}.password-toggle{cursor:pointer;color:var(--color-muted);opacity:.5;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{opacity:1}.admin-login-form button:not(.password-toggle):not(.admin-text-link){background:var(--color-accent);color:#fff;letter-spacing:.04em;cursor:pointer;border:none;border-radius:10px;padding:11px;font-size:13px;font-weight:500;transition:background .2s,transform .1s}.admin-login-form button:not(.password-toggle):not(.admin-text-link):hover{background:var(--color-accent-dark)}.admin-login-form button:not(.password-toggle):not(.admin-text-link):active{transform:scale(.98)}.admin-login-form button:not(.password-toggle):not(.admin-text-link):disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-error{color:#8b4545;background:#fdf2f2;border-radius:8px;margin:0;padding:8px 12px;font-size:12px}.admin-reset-link{text-align:center;margin-top:2px}.admin-text-link{color:var(--color-muted);cursor:pointer;font-size:11px;font-family:var(--font-sans);letter-spacing:.02em;background:0 0;border:none;padding:4px;text-decoration:none;transition:color .2s}.admin-text-link:hover{color:var(--color-accent);text-decoration:underline}.admin-reset-form{border-top:1px solid var(--color-border);flex-direction:column;gap:10px;margin-top:6px;padding-top:14px;display:flex}.admin-reset-form .admin-hint{margin:0}.admin-reset-form input{border:1px solid var(--color-border);font-size:13px;font-family:var(--font-sans);color:var(--color-text);background:#fff;border-radius:10px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.admin-reset-form input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #d4899a1a}.admin-reset-form button{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px;font-size:12px;font-weight:500;transition:background .2s}.admin-reset-form button:hover{background:var(--color-accent-dark)}.admin-reset-form button:disabled{opacity:.5;cursor:not-allowed}.admin-reset-message{color:var(--color-accent);text-align:center;margin:0;font-size:12px}.admin{max-width:1200px;min-height:100dvh;margin:0 auto;padding:24px}.admin-header{margin-bottom:32px}.admin-header-top{justify-content:space-between;align-items:center;display:flex}.admin-logout-btn{font-size:12px;font-family:var(--font-sans);color:var(--color-muted);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:6px;padding:6px 16px;transition:all .2s}.admin-logout-btn:hover{color:var(--color-text);border-color:var(--color-text)}.admin-header h1{color:var(--color-text);letter-spacing:.06em;margin:0 0 16px;font-size:18px;font-weight:400}.admin-tabs{border-bottom:1px solid var(--color-border);gap:4px;display:flex}.admin-tabs button{font-size:13px;font-family:var(--font-sans);color:var(--color-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 20px;transition:all .2s}.admin-tabs button.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.admin-tabs button:hover{color:var(--color-text)}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:var(--color-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-weight:500}.admin-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-light);padding:12px}.admin-back{color:var(--color-accent);cursor:pointer;background:0 0;border:none;margin-bottom:24px;padding:0;font-size:13px}.admin-detail-grid{grid-template-columns:1fr 1fr;gap:32px;display:grid}@media (width<=768px){.admin-detail-grid{grid-template-columns:1fr}}.admin-detail-section h3{color:var(--color-text);margin:0 0 16px;font-size:14px;font-weight:500}.admin-detail-section dl{margin:0}.admin-detail-section dt{color:var(--color-muted);letter-spacing:.06em;margin-top:12px;font-size:11px}.admin-detail-section dd{color:var(--color-text-light);margin:4px 0 0;font-size:14px;line-height:1.7}.admin-letter-preview{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:24px}.admin-letter-keywords{color:var(--color-accent);margin:0 0 12px;font-size:13px}.admin-letter-catchcopy{color:var(--color-text);border-bottom:1px solid var(--color-border);margin:0 0 16px;padding-bottom:16px;font-size:16px}.admin-letter-body p{color:var(--color-text-light);margin:0 0 12px;font-size:13px;line-height:1.9}.admin-actions-list{border-top:1px solid var(--color-border);margin-top:16px;padding-top:16px}.admin-actions-list h4{color:var(--color-muted);margin:0 0 8px;font-size:12px;font-weight:500}.admin-actions-list ul{margin:0;padding-left:20px}.admin-actions-list li{color:var(--color-text-light);margin-bottom:4px;font-size:13px;line-height:1.7}.admin-form{max-width:600px}.admin-form h3{color:var(--color-text);margin:0 0 8px;font-size:14px;font-weight:500}.admin-hint{color:var(--color-muted);margin:0 0 20px;font-size:12px;line-height:1.7}.admin-form label{color:var(--color-muted);margin-bottom:16px;font-size:12px;display:block}.admin-form input,.admin-form textarea{border:1px solid var(--color-border);width:100%;font-size:14px;font-family:var(--font-sans);color:var(--color-text);background:var(--color-card);border-radius:8px;outline:none;margin-top:6px;padding:10px 14px;display:block}.admin-form input:focus,.admin-form textarea:focus{border-color:var(--color-accent)}.admin-form-actions{align-items:center;gap:12px;margin-top:8px;display:flex}.admin-form-actions button{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:13px}.admin-form-actions button:disabled{opacity:.5;cursor:not-allowed}.admin-save-msg{color:var(--color-accent);font-size:13px}.admin-action-btn{border:1px solid var(--color-border);color:var(--color-text-light);cursor:pointer;background:#fff;border-radius:4px;padding:4px 12px;font-size:11px;transition:all .2s}.admin-action-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.admin-action-btn.delete{color:#8b4545;border-color:#e8c4c4}.admin-action-btn.delete:hover{background:#fdf2f2;border-color:#8b4545}
