*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}#root{min-height:100vh}.app{max-width:2500px;margin:0 auto;padding:40px 20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.header-left{flex:1}.header h1{color:#fff;font-size:2.5rem;margin-bottom:10px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.header p{color:#ffffffe6;font-size:1.1rem}.settings-btn{padding:12px 24px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:25px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.settings-btn:hover{background:#ffffff4d}.settings-panel{background:#fff;border-radius:12px;padding:25px;margin-bottom:20px;box-shadow:0 5px 20px #0000001a}.settings-panel h3{margin:0 0 20px;color:#333;font-size:1.2rem}.settings-row{margin-bottom:20px}.settings-row label{display:block;font-weight:600;margin-bottom:8px;color:#555}.settings-row input[type=password],.settings-row input[type=number]{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem}.settings-row input[type=password]:focus,.settings-row input[type=number]:focus{outline:none;border-color:#667eea}.settings-row input[type=color]{width:100%;height:45px;padding:5px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer}.html-preview-container{flex:1;display:flex;flex-direction:column;min-height:0;overflow:visible;width:100%}.html-preview-info{margin-bottom:10px;font-size:.9rem;color:#666;flex-shrink:0}.html-preview-wrapper{width:100%;height:800px;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fff;position:relative}.html-preview-iframe{border:none;transform-origin:top left}.image-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.image-modal-content{position:relative;max-width:95vw;max-height:95vh;cursor:default}.image-modal-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:10px}.image-modal-img{max-width:100%;max-height:95vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #0000004d}.main-container{display:flex;gap:20px;align-items:stretch}.panel:first-child{flex:0 0 550px}.panel:last-child{flex:1}@media (max-width: 900px){.main-container{grid-template-columns:1fr}}.panel{background:#fff;border-radius:16px;padding:30px;box-shadow:0 10px 40px #0000001a;height:1100px;overflow-y:auto}.panel h2{font-size:1.3rem;margin-bottom:20px;color:#333;display:flex;align-items:center;gap:10px}.panel h2:before{content:"";display:inline-block;width:4px;height:24px;background:linear-gradient(180deg,#667eea,#764ba2);border-radius:2px}.input-section{margin-bottom:25px}.input-section label{display:block;font-weight:600;margin-bottom:8px;color:#555}.html-input{width:100%;min-height:200px;padding:15px;border:2px solid #e0e0e0;border-radius:10px;font-family:Monaco,Consolas,monospace;font-size:14px;resize:vertical;transition:border-color .3s}.html-input:focus{outline:none;border-color:#667eea}.drop-zone{border:2px dashed #ccc;border-radius:10px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s;margin-top:15px}.drop-zone:hover,.drop-zone.dragover{border-color:#667eea;background:#667eea0d}.drop-zone-icon{font-size:3rem;margin-bottom:15px}.drop-zone-text{color:#666;font-size:1rem}.drop-zone-hint{color:#999;font-size:.85rem;margin-top:8px}.size-section{margin-bottom:25px}.preset-sizes{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.preset-btn{padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:left}.preset-btn:hover{border-color:#667eea;background:#667eea0d}.preset-btn.active{border-color:#667eea;background:#667eea1a;color:#667eea}.preset-name{font-weight:600;font-size:.9rem;margin-bottom:4px}.preset-size{font-size:.8rem;color:#999}.custom-size{display:flex;gap:15px;align-items:center}.size-input-group{flex:1}.size-input-group label{display:block;font-size:.85rem;color:#666;margin-bottom:5px}.size-input{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;text-align:center}.size-input:focus{outline:none;border-color:#667eea}.format-section{margin-bottom:25px}.format-options{display:flex;gap:10px}.format-btn{flex:1;padding:12px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;font-weight:600}.format-btn:hover{border-color:#667eea}.format-btn.active{border-color:#667eea;background:#667eea;color:#fff}.generate-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite;margin-right:10px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.preview-section{display:flex;flex-direction:column;overflow:auto}.preview-area{flex:1;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:10px;min-height:350px;overflow:hidden;position:relative}.preview-placeholder{text-align:center;color:#999}.preview-placeholder-icon{font-size:4rem;margin-bottom:15px;opacity:.5}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #0000001a}.preview-info{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:8px;font-size:.9rem}.preview-info-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid #eee}.preview-info-row:last-child{border-bottom:none}.preview-info-label{color:#666}.preview-info-value{font-weight:600;color:#333}.preview-actions{display:flex;gap:10px;margin-top:20px}.download-btn,.copy-url-btn{flex:1;padding:12px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.download-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.download-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.copy-url-btn{background:#fff;border:2px solid #667eea;color:#667eea}.copy-url-btn:hover{background:#667eea0d}.copy-success{background:#28a745!important;color:#fff!important;border-color:#28a745!important}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;padding:15px;color:#c00;margin-bottom:20px}.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:15px 30px;border-radius:10px;box-shadow:0 5px 20px #0003;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
