.generator{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);width:100%;height:auto;overflow-y:hidden}.api-setup{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;margin-bottom:15px;padding:1px}.api-setup h3{color:#856404;margin-bottom:5px;font-size:.9em}.api-setup p{color:#856404;margin-bottom:5px;font-size:.8em;line-height:1.4}.api-setup code{background:#f8f9fa;border-radius:4px;padding:2px 6px;font-family:Courier New,monospace}.black-textarea{resize:none;border:1px solid #0c0c0c;border-radius:4px;min-height:8rem}.black-textarea:focus{border-color:#0c0c0c;outline:none}.controls{width:100%;margin-bottom:15px}select{border:2px solid #e1e5e9;border-radius:4px;width:100%;padding:10px;font-family:inherit;font-size:14px}select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.loading{text-align:center;color:#667eea;padding:20px;display:none}.spinner{border:3px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;width:30px;height:30px;margin:0 auto 10px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.image-grid{border:1px solid #0c0c0c;grid-template-columns:repeat(4,1fr);gap:10px;width:100%;min-height:15rem;margin-top:40px;padding:10px;display:grid;box-shadow:inset 1px 3px 6px #050505}.image-card{background:0 0;border-radius:4px;width:100%;height:auto;transition:all .3s;overflow:hidden;box-shadow:0 4px 12px #0000001a}.image-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.image-card img{object-fit:cover;cursor:pointer;max-width:100%;height:auto}.image-info{padding:8px}.image-prompt{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:8px 0;font-size:1rem;font-weight:400;line-height:1.5;display:-webkit-box;overflow:hidden}.image-actions{gap:4px;display:flex}.error,.success{border-radius:4px;margin-bottom:10px;padding:8px;font-size:.8em}.error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.modal{z-index:1000;background-color:#000000e6;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.modal-content{max-width:100vw;max-height:100vh;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.modal img{border-radius:10px;max-width:100vw;height:auto;max-height:100vh}.close{color:#f1f1f1;cursor:pointer;font-size:40px;font-weight:700;position:absolute;top:15px;right:35px}.close:hover{color:#bbb}.black-input{border-radius:5px;font-size:16px;box-shadow:inset 1px 3px 6px #050505}.input-section{margin-bottom:15px}#promptInput::placeholder{color:#666;opacity:1}::-moz-placeholder{color:#5e5e5e}#select-black{border:none;border-radius:0;padding:10px;font-size:14px;box-shadow:inset 1px 3px 6px #050505}.btn-download{background:#077203;width:100%;padding:10px 20px;font-size:1em;font-weight:500}.btn-download:hover{background:#218838}input[type=radio]{display:none}.recorder-group{justify-content:center;align-items:center;width:100%;display:flex}.recorder-label{cursor:pointer;text-align:center;color:#878787;background-color:#333;border-radius:6px;flex-direction:column;align-items:center;gap:.2rem;width:100%;padding:8px;font-family:Montserrat,sans-serif;font-weight:500;transition:all .15s ease-in-out;display:flex;box-shadow:2px 4px 6px #000}.recorder-label span{color:#999;font-size:.8em;display:block}input[type=radio]:checked+.recorder-label{color:#000;background-color:#222;transition:all .15s ease-in-out;box-shadow:1px 1px 4px #40ff3956,inset 1px 1px 1px #414141,inset 2px 1px 2px #077903}input[type=radio]:checked+.recorder-label span,input[type=radio]:checked+.recorder-label .bi{color:#4de048;transition:all .15s ease-in-out;transform:translateY(2px)}.gen-btn{background-color:#171717;border-radius:5px;justify-content:center;align-items:center;display:flex}.gen-button{cursor:pointer;background-color:#4e7931;border:none;border-radius:7px;outline:none;justify-content:center;transition:all .1s ease-in-out;display:flex;box-shadow:10px 10px 8px #00000060,inset 1.5px 1.5px 2px #b5f7a8,inset 3.2px 3.2px 8px #4e7931}.gen-button:active{box-shadow:0 0 #00000060,inset .5px .5px 4px #000,inset -3.2px -3.2px 8px #4e7931}.generator,.image-grid,.controls,.recorder-group,.recorder-label{min-width:0}.generator{box-sizing:border-box}.ai-debug-left{outline:2px dashed #0080ff59}.ai-debug-right{outline:2px dashed #ff008059}.loading-overlay{color:#fff;z-index:1000;background:#000c;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-overlay .spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:60px;height:60px;margin-bottom:20px;animation:1s linear infinite spin}.modal.fullscreen{z-index:2000;background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.fullscreen img{max-width:90%;max-height:90%}
