:root{--primary-color:#dcdc46;--accent-color:#e14e2a;--text-color:#555;--light-text-color:#fff;--bg-color:#fff;--chat-bg-user:#f0f0f0;--chat-bg-bot:#fffde7;--border-color:#e0e0e0;--header-height:60px}*{box-sizing:border-box;padding:0;margin:0}body{font-family:Inter,Noto Sans JP,sans-serif;background-color:var(--bg-color);line-height:1.6;-webkit-font-smoothing:antialiased}a,body{color:var(--text-color)}a{text-decoration:none;transition:opacity .2s}a:hover{opacity:.7}.container{max-width:100%;height:100vh;display:flex;flex-direction:column;background-color:#f9f9f9}.header{height:var(--header-height);background-color:#fff;justify-content:center;border-bottom:1px solid var(--border-color);position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px rgba(0,0,0,.02)}.header,.header-content{display:flex;align-items:center}.header-content{gap:10px}.logo-text{font-family:Inter,sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:.05em;color:var(--text-color);text-transform:uppercase}.logo-sub{font-size:.8rem;color:#888;margin-left:10px;border-left:1px solid #ccc;padding-left:10px}.chat-container{max-width:800px;width:100%;margin:0 auto;overflow:hidden}.chat-container,.chat-window{flex:1 1;padding:20px;display:flex;flex-direction:column}.chat-window{overflow-y:auto;gap:20px;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.05)}.message{max-width:85%;padding:16px 20px;border-radius:16px;font-size:.95rem;line-height:1.7;position:relative;box-shadow:0 1px 2px rgba(0,0,0,.05);min-width:0}.message,.message pre{overflow-wrap:anywhere;word-wrap:break-word;word-break:break-all}.message pre{white-space:pre-wrap;background-color:rgba(0,0,0,.05);padding:8px;border-radius:4px;max-width:100%;overflow-x:auto}.message code{white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere}.message ol,.message p,.message ul{margin-bottom:.5em;word-break:break-all}.message ol,.message ul{margin-left:20px}.message li{word-break:break-all;overflow-wrap:anywhere}.message.user{align-self:flex-end;background-color:var(--chat-bg-user);border-bottom-right-radius:4px;color:var(--text-color)}.message.bot{align-self:flex-start;background-color:var(--chat-bg-bot);border-bottom-left-radius:4px;border:1px solid var(--primary-color);color:var(--text-color)}.message-role{font-size:.75rem;margin-bottom:4px;color:#888;font-weight:700}.input-area-wrapper{background-color:#fff;padding:20px;border-top:1px solid var(--border-color);width:100%}.input-area{max-width:800px;margin:0 auto;display:flex;gap:10px;position:relative}.input-area input{flex:1 1;padding:16px;border:2px solid var(--border-color);border-radius:30px;font-size:1rem;outline:none;transition:border-color .2s;background-color:#fcfcfc}.input-area input:focus{border-color:var(--primary-color);background-color:#fff}.input-area button{padding:0 24px;background-color:var(--accent-color);color:#fff;border:none;border-radius:30px;font-size:1rem;cursor:pointer;font-weight:700;transition:background-color .2s,transform .1s;box-shadow:0 2px 4px rgba(225,78,42,.3);white-space:nowrap}.input-area button.payment-btn{background-color:#ffbf00;color:#000;box-shadow:0 2px 4px rgba(255,191,0,.3)}.input-area button.payment-btn:hover{background-color:#e6ac00}.input-area button:hover{background-color:#c03e1e;transform:translateY(-1px)}.input-area button:active{transform:translateY(1px)}.input-area button:disabled{background-color:#ccc;cursor:not-allowed;box-shadow:none;transform:none}@media (max-width:600px){.input-area{gap:8px}.input-area input{padding:12px 16px;font-size:.95rem}.input-area button{padding:0 16px;font-size:.9rem}}.loading{font-size:.8rem;color:#888;text-align:center;margin-top:10px;font-style:italic}.chat-window::-webkit-scrollbar{width:8px}.chat-window::-webkit-scrollbar-track{background:#f1f1f1}.chat-window::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.chat-window::-webkit-scrollbar-thumb:hover{background:#bbb}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background-color:#fff;padding:30px;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px rgba(0,0,0,.2);position:relative;font-size:.9rem;line-height:1.6}.modal-close-btn{position:-webkit-sticky;position:sticky;top:0;float:right;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#888;z-index:10}.modal-close-btn:hover{color:#333}.modal-body h2{font-size:1.2rem;margin-top:20px;margin-bottom:10px;color:#333;border-bottom:1px solid #eee;padding-bottom:5px}.modal-body h3{font-size:1.1rem;margin-top:15px;margin-bottom:8px;color:#555}.modal-body ul{padding-left:20px;margin-bottom:10px}.modal-body li{margin-bottom:5px}.header-link{font-size:.8rem;color:#888;margin-left:15px;cursor:pointer;text-decoration:underline;white-space:nowrap}.header-link:hover{color:var(--accent-color)}.info-modal-content{max-width:700px}.info-modal-body article{color:#333}.info-modal-body h1{font-size:1.4rem;font-weight:700;color:#222;margin-bottom:16px;line-height:1.5;border-bottom:2px solid var(--primary-color);padding-bottom:10px}.info-modal-body h2{font-size:1.15rem;font-weight:700;color:#333;margin-top:24px;margin-bottom:12px;padding-left:10px;border-left:3px solid var(--accent-color)}.info-modal-body p{margin-bottom:12px;text-align:justify}.info-modal-body a{color:var(--accent-color);text-decoration:underline}.info-modal-body a:hover{opacity:.8}.info-modal-body strong{color:#222}