.settings-panel.generating{opacity:.6;pointer-events:none;filter:grayscale(.5);cursor:wait}.settings-panel.generating *{cursor:wait!important}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a10;--surface:#141420;--surface2:#1c1c2e;--surface3:#242438;--border:rgba(255,255,255,.09);--border2:rgba(255,255,255,.16);--border-accent:rgba(130,100,255,.4);--text:#f0eef6;--text2:rgba(240,238,246,.65);--text3:rgba(240,238,246,.42);--accent:#8b6cff;--accent2:#c084fc;--accent-glow:rgba(139,108,255,.14);--gemini:#4285f4;--gemini-glow:rgba(66,133,244,.14);--openai:#10a37f;--openai-glow:rgba(16,163,127,.14);--success:#34d399;--danger:#f87171;--radius:12px;--radius-sm:8px;--radius-xs:6px;--mt-4:4px;--font-sans:"Inter","Noto Sans JP",-apple-system,BlinkMacSystemFont,sans-serif;--font-serif:"Noto Serif JP",Georgia,serif;--transition:all .2s cubic-bezier(.4,0,.2,1)}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% -10%,var(--accent-glow),transparent 70%);pointer-events:none;z-index:0}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.hidden{display:none!important}.title-bar{position:relative;z-index:1;display:flex;align-items:baseline;gap:10px;padding:18px 24px 16px;background:linear-gradient(180deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border)}.title-bar h1{font-size:28px;font-weight:900;letter-spacing:-.03em;background:linear-gradient(135deg,#fff 30%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:10px}.logo-icon{flex-shrink:0;filter:drop-shadow(0 0 6px rgba(139,108,255,.5))}.title-version{font-size:15px;background:none;-webkit-text-fill-color:var(--accent);font-family:monospace;font-weight:800}.title-sub{font-size:15px;color:var(--text2);font-weight:600}#banner{position:relative;z-index:1;background:var(--surface);border-bottom:1px solid var(--border);padding:10px 24px 8px;display:flex;flex-direction:column;gap:4px;transition:var(--transition)}#banner.locked .banner-row input,#banner.locked .banner-row select{opacity:.6;pointer-events:none;background:#00000026;cursor:not-allowed}#banner.ok .banner-status{color:var(--success)}.banner-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.banner-label{font-size:13px;font-weight:800;color:var(--gemini);letter-spacing:.04em;white-space:nowrap;padding:5px 12px;background:var(--gemini-glow);border:1px solid rgba(66,133,244,.3);border-radius:var(--radius-xs);margin-right:8px}#apikey{flex:1;min-width:120px;padding:7px 11px;border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-family:SF Mono,Cascadia Code,monospace;background:var(--bg);color:var(--text);outline:none;transition:var(--transition)}#apikey:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}#model-select{padding:7px 28px 7px 11px;border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-size:12px;font-family:var(--font-sans);outline:none;cursor:pointer;min-width:160px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239b98a0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}#key-save{padding:7px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-xs);font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font-sans);transition:var(--transition);white-space:nowrap}#key-save:hover{opacity:.85;transform:translateY(-1px)}#key-edit{padding:7px 14px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition)}#key-edit:hover{border-color:var(--accent);color:var(--accent)}.api-notice{font-size:11px;color:#fbbf24;line-height:1.4;padding:4px 2px 0;letter-spacing:.02em}.banner-status{font-size:11px;color:var(--text3);line-height:1.3}.main-wrap{position:relative;z-index:1;display:grid;grid-template-columns:460px 1fr;min-height:calc(100vh - 120px)}.settings-panel{background:var(--surface);border-right:1px solid var(--border);padding:0;display:flex;flex-direction:column;overflow:hidden;position:sticky;top:0;height:calc(100vh - 120px);transition:opacity .3s ease,filter .3s ease}.panel-fixed-top{flex-shrink:0;padding:16px 18px 12px;display:flex;flex-direction:column;gap:12px;border-bottom:1px solid var(--border);background:var(--surface);z-index:2}.panel-scroll{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.settings-panel.disabled-panel{opacity:.4;pointer-events:none;filter:grayscale(80%)}.output-panel{min-width:0;padding:24px;display:flex;flex-direction:column;gap:16px;height:calc(100vh - 120px);overflow-y:auto;scroll-behavior:smooth}.global-alert-yellow{background:#fbbf241f;border-bottom:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:8px 24px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px}.panel-top-actions{display:flex;gap:8px}.btn-all-random{flex:1;padding:11px;background:none;border:2px dashed var(--border2);border-radius:var(--radius);font-size:12px;font-weight:700;color:var(--text);cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;justify-content:center;gap:6px;transition:var(--transition)}.btn-all-random:hover{background:var(--accent-glow);border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-1px)}.btn-util{padding:11px 14px;background:none;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text3);cursor:pointer;transition:var(--transition)}.btn-util:hover{border-color:var(--danger);color:var(--danger);background:#f8717114}.btn-util:last-child:hover{border-color:var(--gemini);color:var(--gemini);background:var(--gemini-glow)}.divider{border:none;height:1px;background:var(--border);margin:2px 0}.settings-panel.generating{pointer-events:none;opacity:.5;transition:opacity .3s}.s-section{display:flex;flex-direction:column;gap:7px}.s-label{font-size:12px;font-weight:800;color:var(--text);letter-spacing:.08em;display:flex;align-items:center;justify-content:space-between;width:100%;-webkit-user-select:none;user-select:none}.s-label-actions{display:flex;align-items:center;gap:6px}.btn-rnd{font-size:10px;padding:3px 10px;border:1px solid var(--border-accent);border-radius:14px;background:#8b6cff0f;color:var(--accent2);cursor:pointer;font-family:var(--font-sans);transition:var(--transition);white-space:nowrap;font-weight:600}.btn-rnd:hover{background:var(--accent-glow);color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.btn-rnd:active{transform:scale(.95)}.btn-rnd.btn-rand-all{border-color:var(--border-accent);background:#8b6cff14;color:var(--accent);font-weight:700}.btn-section-clear{font-size:13px;background:none;border:none;color:var(--text3);cursor:pointer;transition:var(--transition);opacity:.4;padding:3px}.btn-section-clear:hover{color:var(--danger);opacity:1;transform:scale(1.1) rotate(10deg)}#btn-today-news{border-color:var(--success);color:var(--success);background:#34d3990d}#btn-today-news:hover{background:#34d39926;box-shadow:0 0 8px #34d39933}.chips{display:flex;flex-wrap:wrap;gap:4px}.chips-sub{margin-top:4px}.chip{padding:4px 11px;border-radius:18px;border:1px solid var(--border2);background:#ffffff08;color:var(--text2);font-size:11px;cursor:pointer;font-family:var(--font-sans);transition:var(--transition);font-weight:600;white-space:nowrap}.chip:hover{border-color:#ffffff40;color:var(--text);background:#ffffff0f}.chip.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent);font-weight:700;box-shadow:0 0 10px var(--accent-glow);-webkit-user-select:none;user-select:none}.chip.cat-chip{background:var(--surface3);border-color:var(--border2);font-weight:700;color:var(--text)}.chip.cat-chip.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent)}.chip.sub-chip{font-size:11px;background:var(--bg)}.chip.sub-chip.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent)}.custom-input-wrap{position:relative;margin-top:4px}.custom-input-wrap .custom-input{padding-right:86px}.custom-clear-btn{position:absolute;right:56px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:none;border-radius:50%;background:#ffffff0f;color:var(--text3);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:2}.custom-clear-btn:hover{background:#f871712e;color:var(--danger);transform:translateY(-50%) rotate(15deg)}.custom-clear-btn.hidden{display:none}.custom-rnd-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:3px 10px;border:1px solid var(--border-accent);border-radius:14px;background:linear-gradient(135deg,#8b6cff1a,#c084fc2e);color:var(--accent);font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:3px;transition:var(--transition);z-index:2;white-space:nowrap;animation:subtlePulse 3s ease-in-out infinite}.custom-rnd-btn:hover{background:linear-gradient(135deg,#8b6cff33,#c084fc4d);box-shadow:0 0 10px var(--accent-glow);transform:translateY(-50%) scale(1.05)}.custom-rnd-btn:active{transform:translateY(-50%) scale(.92)}@keyframes subtlePulse{0%,to{box-shadow:0 0 #8b6cff00}50%{box-shadow:0 0 8px 2px #8b6cff2e}}.custom-input{font-size:12px;padding:6px 10px;border:1px dashed var(--border2)!important;border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-family:var(--font-sans);outline:none;transition:var(--transition);width:100%}.custom-input::placeholder{color:var(--text3);font-size:11px}.custom-input:not(:placeholder-shown){border-color:var(--accent)!important;border-style:solid!important;background:#8b6cff0a}.custom-input:focus{border-color:var(--accent)!important;box-shadow:0 0 0 3px var(--accent-glow)}.charcount-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;margin-top:4px;padding:6px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:#ffffff05;transition:var(--transition);-webkit-user-select:none;user-select:none}.charcount-toggle:hover{border-color:#fff3;background:#ffffff0a}.charcount-toggle input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.charcount-toggle-label{font-size:12px;font-weight:600;color:var(--text2)}.charcount-field{display:flex;align-items:center;gap:6px;margin-top:4px}.charcount-field input{width:120px;padding:6px 10px;font-size:13px;font-weight:600;font-family:monospace}.charcount-unit{font-size:12px;color:var(--text3);font-weight:600}input[type=text],input[type=number],textarea,select{width:100%;padding:7px 11px;border:1px solid var(--border2);border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:13px;outline:none;transition:var(--transition)}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}textarea{resize:vertical;min-height:56px;line-height:1.6}.char-controls{display:flex;align-items:center;gap:10px}.char-controls-label{font-size:13px;color:var(--text3);font-weight:600}.stepper{display:flex;align-items:center;border:1px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg)}.stepper-btn{width:34px;height:34px;background:none;border:none;color:var(--text);font-size:18px;font-weight:700;cursor:pointer;font-family:var(--font-sans);transition:var(--transition);display:flex;align-items:center;justify-content:center}.stepper-btn:hover{background:var(--accent-glow);color:var(--accent)}.stepper-value{min-width:34px;text-align:center;font-size:16px;font-weight:800;color:var(--text);font-family:monospace;border-left:1px solid var(--border);border-right:1px solid var(--border);padding:5px 0}.char-hint{font-size:10px;color:var(--text3);line-height:1.5}.char-preset.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent);font-weight:700}.char-field-row{display:flex;align-items:center;gap:4px;margin-bottom:4px;position:relative}.char-field-row .input-wrap{flex:1;position:relative}.char-field-row .btn-group{display:flex;gap:2px}.char-field-btn{width:auto;min-width:24px;height:24px;padding:0 6px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text3);font-size:11px;cursor:pointer;transition:var(--transition)}.char-field-btn:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.char-field-btn.delete{color:var(--text3)}.char-field-btn.delete:hover{border-color:var(--danger);color:var(--danger);background:#f871711a}.char-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.char-card-num{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:.1em}.btn-char-del{font-size:10px;padding:2px 8px;border:1px solid var(--border);border-radius:4px;background:none;color:var(--text3);cursor:pointer;transition:var(--transition)}.btn-char-del:hover{border-color:var(--danger);color:var(--danger);background:#f871711a}.char-field-label{font-size:10px;color:var(--text3);margin-bottom:2px;display:block;font-weight:600}.char-section-hint{font-size:10px;color:var(--text3);line-height:1.6;padding:8px 12px;background:#ffffff03;border:1px dashed var(--border);border-radius:8px;margin-top:10px}.char-section-hint strong{color:var(--accent)}.char-custom-wrap{position:relative;margin-top:2px}.char-custom-wrap .char-custom{padding-right:80px}.char-custom{font-size:11px;padding:5px 9px;border:1px dashed var(--border)!important;border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-family:var(--font-sans);outline:none;width:100%;transition:var(--transition)}.char-custom::placeholder{color:var(--text3);font-size:10px;font-style:italic}.char-custom:focus{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent-glow)}.char-custom:not(:placeholder-shown){border-color:var(--accent)!important;border-style:solid!important;background:#8b6cff0a}.char-custom-clear{position:absolute;right:50px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;border-radius:50%;background:#ffffff0f;color:var(--text3);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:2}.char-custom-clear:hover{background:#f871712e;color:var(--danger);transform:translateY(-50%) rotate(15deg)}.char-custom-clear.hidden{display:none}.char-custom-rnd{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:2px 8px;border:1px solid var(--border-accent);border-radius:10px;background:linear-gradient(135deg,#8b6cff1a,#c084fc26);color:var(--accent);font-size:9px;font-weight:700;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:2px;white-space:nowrap;transition:var(--transition);z-index:2}.char-custom-rnd:hover{background:linear-gradient(135deg,#8b6cff33,#c084fc4d);box-shadow:0 0 6px var(--accent-glow)}.char-placeholder{font-size:12px;color:var(--text3);text-align:center;padding:14px;border:1px dashed var(--border);border-radius:var(--radius-sm);line-height:1.6}.textarea-wrap{position:relative}.textarea-clear-btn{position:absolute;right:8px;top:8px;width:24px;height:24px;border:none;border-radius:var(--radius-xs);background:#ffffff0d;color:var(--text3);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:2}.textarea-clear-btn:hover{background:#f8717126;color:var(--danger);transform:rotate(12deg)}.textarea-clear-btn.hidden{display:none}.mt-4{margin-top:var(--mt-4)}.btn-generate{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:var(--radius);padding:14px;font-size:14px;font-weight:700;cursor:pointer;width:100%;font-family:var(--font-sans);transition:var(--transition);position:relative;overflow:hidden;margin-top:4px}.btn-generate:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .5s}.btn-generate:hover:before{left:100%}.btn-generate:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #8b6cff4d}.btn-generate:disabled{opacity:.3;cursor:not-allowed;transform:none}.output-header{display:flex;align-items:center;justify-content:space-between}.output-title{font-size:11px;font-weight:800;color:var(--text3);letter-spacing:.14em;text-transform:uppercase}.output-actions{display:flex;align-items:center;gap:8px}.char-counter{font-size:11px;font-family:monospace;color:var(--text3);font-weight:600}.tag-row{display:flex;flex-wrap:wrap;gap:5px}.tag{font-size:10px;padding:3px 10px;border-radius:14px;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-weight:600}.tag-gemini{color:var(--gemini);border-color:#4285f440;background:var(--gemini-glow)}.tag-model{font-size:9px;color:var(--text3);border-color:var(--border)}.tag-warn{color:#fbbf24;border-color:#fbbf244d;background:#fbbf240d}.output-box{max-width:100%;flex:0 0 auto;margin-bottom:16px;word-break:break-word;overflow-wrap:anywhere;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;font-size:15px;line-height:2;white-space:pre-wrap;min-height:200px;max-height:calc(100vh - 280px);overflow-y:auto;font-family:var(--font-serif);color:var(--text);box-shadow:0 2px 8px #0003}.output-box pre{white-space:pre-wrap;word-break:break-all;overflow-x:hidden}.output-box.empty{color:var(--text2);font-size:13px;font-family:var(--font-sans);line-height:1.8;white-space:normal}.error-msg{color:var(--danger);font-weight:600;display:flex;align-items:center;gap:8px}.btn-action{font-size:12px;padding:5px 12px;border:1px solid var(--border2);border-radius:var(--radius-xs);background:none;color:var(--text2);cursor:pointer;font-family:var(--font-sans);transition:var(--transition);font-weight:600;white-space:nowrap}.btn-action:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--border-accent)}.output-guide{display:flex;flex-direction:column;gap:14px;padding:20px 10px}.guide-title{font-size:14px;font-weight:800;color:var(--text);letter-spacing:.02em}.guide-step{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text2)}.guide-num{width:26px;height:26px;border-radius:50%;background:var(--accent-glow);border:1px solid var(--border-accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--accent);flex-shrink:0}.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.main-wrap{grid-template-columns:1fr}.settings-panel{position:static;height:auto;overflow:visible}.panel-scroll{overflow-y:visible}.banner-row{flex-direction:column;align-items:stretch}.title-bar{flex-wrap:wrap;gap:6px 10px}.title-bar h1{font-size:22px}}.charcount-option .hint-text{font-size:.85em;margin-top:5px;margin-bottom:0}.charcount-option .text-muted{color:#aaa}.ci-dropzone{border:2px dashed var(--border2);border-radius:var(--radius);padding:18px 16px;text-align:center;cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#8b6cff08,#4285f408);margin:8px 0;position:relative;overflow:hidden}.ci-dropzone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#8b6cff14,#4285f414);opacity:0;transition:opacity .3s ease}.ci-dropzone:hover{border-color:var(--accent);background:linear-gradient(135deg,#8b6cff0f,#4285f40f)}.ci-dropzone:hover:before{opacity:1}.ci-dropzone.ci-dragover{border-color:var(--accent);border-style:solid;background:linear-gradient(135deg,#8b6cff1f,#4285f41a);box-shadow:0 0 30px #8b6cff40,inset 0 0 20px #8b6cff14;transform:scale(1.01)}.ci-dropzone.ci-loading{pointer-events:none;opacity:.7}.ci-dropzone-icon{font-size:28px;margin-bottom:6px;filter:grayscale(.2);transition:var(--transition);position:relative;z-index:1}.ci-dropzone:hover .ci-dropzone-icon{filter:none;transform:scale(1.1)}.ci-dropzone-text{position:relative;z-index:1;display:flex;flex-direction:column;gap:2px}.ci-dropzone-text strong{font-size:12px;color:var(--text);font-weight:700}.ci-dropzone-text span{font-size:10px;color:var(--text3)}.ci-dropzone-hint{font-size:9px;color:var(--text3);margin-top:4px;opacity:.7;position:relative;z-index:1}.ci-status{font-size:11px;font-weight:600;padding:6px 12px;border-radius:var(--radius-xs);background:#8b6cff0f;border:1px solid var(--border-accent);color:var(--accent);text-align:center;margin-top:4px}.ci-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:ciFadeIn .3s ease}@keyframes ciFadeIn{0%{opacity:0}to{opacity:1}}.ci-modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #00000080,0 0 40px #8b6cff1a;animation:ciSlideUp .3s ease}@keyframes ciSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.ci-modal-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.ci-modal-title{font-size:15px;font-weight:800;color:var(--text);flex:1}.ci-modal-count{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-glow);padding:3px 10px;border-radius:12px;border:1px solid var(--border-accent)}.ci-modal-close{width:28px;height:28px;border:1px solid var(--border);border-radius:8px;background:none;color:var(--text3);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.ci-modal-close:hover{border-color:var(--danger);color:var(--danger);background:#f8717114}.ci-thumbnail-wrap{padding:12px 20px 0;display:flex;justify-content:center;flex-wrap:wrap;gap:8px}.ci-thumbnail{max-height:100px;border-radius:8px;border:1px solid var(--border);opacity:.8;object-fit:contain}.ci-char-list{padding:12px 20px;display:flex;flex-direction:column;gap:10px}.ci-char-card{background:var(--bg);border:1px solid var(--border2);border-radius:var(--radius);padding:12px 14px;transition:var(--transition)}.ci-char-card:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.ci-char-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.ci-check-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:700;color:var(--text)}.ci-check{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.ci-char-name-display{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800}.ci-char-badge{font-size:9px;color:var(--text3);background:#ffffff08;border:1px solid var(--border);border-radius:10px;padding:2px 8px;font-weight:600}.ci-char-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ci-field{display:flex;flex-direction:column;gap:3px}.ci-field-full{grid-column:1 / -1}.ci-field-label{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}.ci-input{padding:5px 8px!important;font-size:12px!important;border-radius:6px!important}.ci-select-wrap{display:flex;flex-direction:column;gap:3px}.ci-select{padding:4px 6px!important;font-size:10px!important;border-radius:4px!important;background:var(--surface2)!important;border-color:var(--border)!important;color:var(--text3)!important}.ci-textarea{padding:6px 8px!important;font-size:11px!important;line-height:1.5!important;border-radius:6px!important;min-height:48px!important}.ci-modal-actions{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--surface)}.ci-btn{flex:1;padding:10px;border:none;border-radius:var(--radius-xs);font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font-sans);transition:var(--transition)}.ci-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}.ci-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #8b6cff4d}.ci-btn-secondary{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.ci-btn-secondary:hover{border-color:var(--danger);color:var(--danger)}.char-controls-row{display:flex;align-items:center;gap:6px}.char-count-display{font-size:20px;font-weight:800;color:var(--accent);min-width:24px;text-align:center;font-family:monospace}.char-unit{font-size:12px;color:var(--text3)}.btn-secondary{font-size:12px;padding:5px 12px;border:1px solid var(--border2);border-radius:var(--radius-xs);background:none;color:var(--text2);cursor:pointer;font-family:var(--font-sans);transition:var(--transition);font-weight:600}.btn-secondary:hover{background:var(--accent-glow);color:var(--accent)}.section-hint{font-size:10px;color:var(--text3);line-height:1.5;margin-top:4px}.text-selectable{-webkit-user-select:text!important;user-select:text!important}.generate-wrap{margin-top:4px}.custom-textarea-wrap{position:relative}.custom-textarea{width:100%;padding:8px 30px 8px 10px;border:1px dashed var(--border2);border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:12px;outline:none;resize:vertical;min-height:56px;line-height:1.6;transition:var(--transition)}.custom-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.custom-textarea:not(:placeholder-shown){border-color:var(--accent);border-style:solid;background:#8b6cff0a}.custom-textarea-wrap .custom-clear-btn{right:6px;top:8px;transform:none}.char-cards{display:flex;flex-direction:column;gap:8px}.char-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.shadow-sm{box-shadow:0 1px 3px #00000026}.guide h3{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--accent)}.guide ol{padding-left:20px}.guide li{margin-bottom:6px;font-size:13px;color:var(--text2);line-height:1.6}@media(max-width:640px){.ci-char-fields{grid-template-columns:1fr}.ci-modal{max-height:90vh}}.sa-beta-section{flex:0 0 auto;margin:0;padding:16px 0 24px;border-top:1px solid var(--border)}.sa-beta-section.sa-inactive .sa-block,.sa-beta-section.sa-inactive .sa-beta-banner{opacity:.25;pointer-events:none;filter:grayscale(.8)}.sa-inactive-msg{text-align:center;padding:16px;font-size:12px;font-weight:700;color:var(--text3);background:#ffffff05;border:1px dashed var(--border);border-radius:var(--radius);margin-bottom:12px;letter-spacing:.04em}.sa-beta-section:not(.sa-inactive) .sa-inactive-msg{display:none}.sa-result-wrap{margin-top:14px}.sa-reflect-wrap{margin-top:8px}.sa-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.sa-api-status{display:flex;align-items:center;gap:8px;padding:8px 14px;margin-bottom:10px;font-size:11px;font-weight:700;color:#fbbf24;background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:var(--radius);letter-spacing:.02em;animation:saStatusPulse 2s ease-in-out infinite}@keyframes saStatusPulse{0%,to{opacity:1}50%{opacity:.7}}.sa-api-status .spinner{margin-right:4px}.sa-format-hint{font-size:10px;color:var(--text3);padding:6px 10px;margin-bottom:10px;background:#8b6cff0a;border-left:2px solid rgba(139,108,255,.3);border-radius:0 var(--radius) var(--radius) 0;line-height:1.6}.sa-beta-banner{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;margin:24px 0 20px;background:#fbbf240f;border:1px solid rgba(251,191,36,.25);border-radius:var(--radius);border-left:4px solid #fbbf24}.sa-beta-badge{flex-shrink:0;padding:4px 12px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e;font-size:11px;font-weight:900;border-radius:20px;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 2px 8px #fbbf244d;animation:betaPulse 3s ease-in-out infinite}@keyframes betaPulse{0%,to{box-shadow:0 2px 8px #fbbf244d}50%{box-shadow:0 2px 16px #fbbf2480}}.sa-beta-text{display:flex;flex-direction:column;gap:4px}.sa-beta-text strong{font-size:14px;color:#fbbf24;font-weight:800}.sa-beta-text span{font-size:11px;color:var(--text3);line-height:1.5}.sa-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px}.sa-block-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.sa-block-header .output-actions{margin-left:auto;display:flex;gap:6px}.sa-block-header .sa-reflect-counter{margin-left:auto}.sa-block-title{font-size:13px;font-weight:800;color:var(--text);letter-spacing:.04em}.sa-btn-small{margin-left:auto;font-size:10px!important;padding:3px 10px!important}.sa-desc{font-size:11px;color:var(--text3);line-height:1.7;margin-bottom:14px}.sa-dropzone{border:2px dashed var(--border2);border-radius:var(--radius);padding:22px 16px;text-align:center;cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#fbbf2408,#8b6cff08);position:relative;overflow:hidden}.sa-dropzone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#fbbf2414,#8b6cff14);opacity:0;transition:opacity .3s ease}.sa-dropzone:hover{border-color:#fbbf24;background:linear-gradient(135deg,#fbbf240f,#8b6cff0f)}.sa-dropzone:hover:before{opacity:1}.sa-dropzone.sa-dragover{border-color:#fbbf24;border-style:solid;background:linear-gradient(135deg,#fbbf241f,#8b6cff1a);box-shadow:0 0 30px #fbbf2440,inset 0 0 20px #fbbf2414;transform:scale(1.01)}.sa-dropzone.sa-has-files{border-color:var(--success);border-style:solid;background:#34d3990a}.sa-dropzone-icon{font-size:32px;margin-bottom:6px;position:relative;z-index:1;transition:var(--transition)}.sa-dropzone:hover .sa-dropzone-icon{transform:scale(1.15) rotate(-5deg)}.sa-dropzone-text{position:relative;z-index:1;display:flex;flex-direction:column;gap:3px}.sa-dropzone-text strong{font-size:12px;color:var(--text);font-weight:700}.sa-dropzone-text span{font-size:10px;color:var(--text3)}.sa-dropzone-hint{font-size:9px;color:var(--text3);margin-top:6px;opacity:.7;position:relative;z-index:1}.sa-file-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.sa-file-item{display:flex;align-items:center;gap:8px;padding:5px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:11px}.sa-file-name{flex:1;color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-file-chars{font-size:10px;color:var(--text3);font-family:monospace;font-weight:600}.sa-file-remove{width:20px;height:20px;border:none;border-radius:4px;background:none;color:var(--text3);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.sa-file-remove:hover{color:var(--danger);background:#f871711a}.sa-file-count{font-size:10px;font-weight:700;color:var(--success);background:#34d39914;padding:2px 10px;border-radius:12px;border:1px solid rgba(52,211,153,.2);font-family:monospace}.sa-btn-action{width:100%;padding:12px;border:none;border-radius:var(--radius);font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font-sans);transition:var(--transition);background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e;position:relative;overflow:hidden;margin-bottom:14px}.sa-btn-action:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.sa-btn-action:hover:before{left:100%}.sa-btn-action:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #fbbf244d}.sa-btn-action:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.sa-btn-action:disabled:before{display:none}.sa-btn-reflect{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}.sa-btn-reflect:hover{box-shadow:0 6px 20px #8b6cff4d}.sa-result-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:18px;font-size:12px;line-height:1.8;white-space:pre-wrap;word-break:break-word;color:var(--text);font-family:var(--font-sans);max-height:500px;overflow-y:auto;margin-bottom:10px}.sa-result-box.sa-error{border-color:var(--danger);color:var(--danger)}.sa-reflect-output{font-family:var(--font-serif);font-size:14px;line-height:2}.sa-reflect-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sa-reflect-counter{font-size:11px;font-family:monospace;color:var(--text3);font-weight:600}.sa-footer{text-align:center;padding:16px 0 0;font-size:10px;color:var(--text3);opacity:.5;letter-spacing:.08em}@media(max-width:900px){.sa-beta-section{padding:0 12px 24px}.sa-beta-banner{flex-direction:column;gap:8px}}
