*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.App{margin:0 auto;max-width:1200px;padding:20px}.App-header{color:#fff;margin-bottom:30px;padding:20px;text-align:center}.App-header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px #0000004d}.subtitle{font-size:1.1rem;opacity:.9}.App-main{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0003;padding:30px}.upload-section{margin-bottom:30px}.image-uploader{background:#f8f9fa;border:3px dashed #667eea;border-radius:10px;cursor:pointer;padding:40px;text-align:center;transition:all .3s ease}.image-uploader:hover{background:#f0f0f0;border-color:#764ba2}.upload-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 30px;transition:transform .2s ease,box-shadow .2s ease}.upload-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.upload-button:active{transform:translateY(0)}.upload-hint{color:#666;font-size:.9rem;margin-top:15px}.upload-info{color:#999;font-size:.85rem;margin-top:5px}.preview-section{margin-top:20px;text-align:center}.preview-section h3{color:#333;margin-bottom:15px}.preview-image{border-radius:10px;box-shadow:0 4px 10px #0000001a;max-height:400px;max-width:100%}.controls-section{background:#f8f9fa;border-radius:10px;margin:30px 0;padding:20px}.style-selector{margin-bottom:20px}.style-selector h3{color:#333;margin-bottom:15px}.style-options{display:flex;flex-wrap:wrap;gap:10px}.style-option{background:#fff;border:2px solid #ddd;border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .3s ease}.style-option:hover{border-color:#667eea;transform:translateY(-2px)}.style-option.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.stained-glass-toggle{margin:20px 0}.toggle-hint{color:#666;font-size:.85rem;margin-left:30px;margin-top:5px}.process-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:20px;padding:15px;transition:all .3s ease;width:100%}.process-button:hover:not(:disabled){box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.process-button:disabled{cursor:not-allowed;opacity:.6}.progress-indicator{margin:20px 0;padding:30px;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 15px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.progress-indicator p{color:#666;font-size:1rem;margin-bottom:15px}.progress-bar-container{background:#e0e0e0;border-radius:4px;height:8px;margin:15px auto;max-width:400px;overflow:hidden;width:100%}.progress-bar{animation:pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.progress-text{color:#667eea;font-size:.9rem;font-weight:600;margin-top:5px}.error-message{background:#fee;border:2px solid #fcc;border-radius:10px;color:#c33;margin:20px 0;padding:15px}.result-viewer{background:#f8f9fa;border-radius:10px;margin-top:30px;padding:20px}.result-viewer h3{color:#333}.result-image-container,.result-viewer h3{margin-bottom:20px;text-align:center}.result-image{border-radius:10px;box-shadow:0 4px 15px #0003;max-height:600px;max-width:100%}.result-stats{background:#fff;border-radius:10px;margin:20px 0;padding:20px}.result-stats h4{color:#333;margin-bottom:15px}.result-stats ul{list-style:none}.result-stats li{border-bottom:1px solid #eee;color:#666;padding:8px 0}.result-stats li:last-child{border-bottom:none}.result-stats li.info-note{color:#667eea;font-size:.9rem;font-style:italic}.download-button{background:#28a745;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:20px;padding:12px;transition:all .3s ease;width:100%}.download-button:hover{background:#218838;box-shadow:0 5px 15px #28a7454d;transform:translateY(-2px)}.App-footer{color:#fff;margin-top:30px;opacity:.8;padding:20px;text-align:center}@media (max-width:768px){.App-header h1{font-size:2rem}.App-main{padding:20px}.style-options{justify-content:center}.style-option{flex:1 1;min-width:100px}}.export-options{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin:20px 0;padding:20px}.export-options h4{color:#333;font-size:18px;margin:0 0 15px}.export-controls{gap:15px;margin-bottom:20px}.control-group,.export-controls{display:flex;flex-direction:column}.control-group{gap:5px}.control-group label{color:#333;font-size:14px;font-weight:500}.control-group input[type=text],.control-group select{border:1px solid #ddd;border-radius:5px;color:#333;font-size:14px;padding:8px 12px}.control-group input[type=text]:focus,.control-group select:focus{border-color:#9b59b6;box-shadow:0 0 0 2px #9b59b633;outline:none}.control-group input[type=range]{-webkit-appearance:none;background:#e0e0e0;border-radius:3px;height:6px;outline:none;width:100%}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#9b59b6;border-radius:50%;cursor:pointer;height:18px;width:18px}.control-group input[type=range]::-moz-range-thumb{background:#9b59b6;border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.export-buttons{display:flex;flex-wrap:wrap;gap:10px}.export-button{border:none;border-radius:5px;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;min-width:120px;padding:12px 20px;transition:all .2s}.export-button.primary{background:#9b59b6;color:#fff}.export-button.primary:hover{background:#8e44ad;box-shadow:0 4px 8px #9b59b64d;transform:translateY(-1px)}.export-button.secondary{background:#ecf0f1;color:#333}.export-button.secondary:hover{background:#d5dbdb;transform:translateY(-1px)}.line-art-converter{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin:20px 0;padding:20px}.line-art-toggle{margin-bottom:15px}.toggle-label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:10px}.toggle-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.toggle-description{color:#666;font-size:14px;font-style:italic;margin:8px 0 0 30px}.line-art-settings{border-top:1px solid #e0e0e0;margin-top:15px;padding-top:15px}.setting-group{margin-bottom:20px}.setting-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.setting-group select{background:#fff;border:1px solid #ddd;border-radius:5px;color:#333;cursor:pointer;font-size:14px;padding:10px;width:100%}.setting-group select:focus{background:#fff;border-color:#9b59b6;box-shadow:0 0 0 2px #9b59b633;outline:none}.setting-group input[type=range]{-webkit-appearance:none;background:#e0e0e0;border-radius:3px;height:6px;outline:none;width:100%}.setting-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#9b59b6;border-radius:50%;cursor:pointer;height:18px;width:18px}.setting-group input[type=range]::-moz-range-thumb{background:#9b59b6;border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.range-labels{color:#666;display:flex;font-size:12px;justify-content:space-between;margin-top:5px}.image-history{background:#f8f9fa;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:20px 0;padding:20px}.history-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;-webkit-user-select:none;user-select:none}.history-header h3{color:#333;font-size:1.2rem;margin:0}.history-toggle{align-items:center;background:#e8ecff;border-radius:50%;color:#667eea;display:flex;font-size:1.5rem;font-weight:700;height:30px;justify-content:center;transition:all .2s ease;width:30px}.history-header:hover .history-toggle{background:#d0d8ff;transform:scale(1.1)}.history-content{margin-top:16px}.history-empty{color:#999;font-style:italic;padding:40px 20px;text-align:center}.history-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-bottom:16px}.history-item{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;overflow:hidden;transition:all .2s ease}.history-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.history-item-image{background:#f0f0f0;overflow:hidden;padding-top:100%;position:relative;width:100%}.history-item-image img{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.history-item-delete{align-items:center;background:#ff4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;line-height:1;opacity:0;position:absolute;right:4px;top:4px;transition:all .2s ease;width:24px}.history-item:hover .history-item-delete{opacity:1}.history-item-delete:hover{background:#c00;transform:scale(1.1)}.history-item-info{display:flex;flex-direction:column;gap:4px;padding:8px}.history-item-style{color:#333;font-size:.85rem;font-weight:600;text-transform:capitalize}.history-item-time{color:#999;font-size:.75rem}.history-clear{background:#f44;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px;transition:all .2s ease;width:100%}.history-clear:hover{background:#c00;transform:translateY(-1px)}.educational-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.educational-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;line-height:1.8;margin:0 auto;max-width:900px;padding:40px}.educational-header{border-bottom:3px solid #4a90e2;margin-bottom:50px;padding-bottom:30px;text-align:center}.educational-header h1{color:#2c3e50;font-size:2.5em;margin-bottom:10px}.educational-section{margin-bottom:40px}.educational-section h2{border-bottom:2px solid #ecf0f1;color:#2c3e50;font-size:1.8em;margin-bottom:20px;padding-bottom:10px}.educational-section h3{color:#34495e;font-size:1.4em;margin-bottom:15px;margin-top:30px}.educational-section h4{color:#34495e;font-size:1.2em;margin-bottom:10px;margin-top:20px}.content-block{background:#f8f9fa;border-left:4px solid #4a90e2;border-radius:8px;margin-bottom:20px;padding:25px}.content-block p{color:#2c3e50;margin-bottom:15px}.content-block ol,.content-block ul{color:#2c3e50;margin-bottom:15px;margin-left:25px}.content-block li{margin-bottom:10px}.content-block strong{color:#2c3e50;font-weight:600}blockquote{background:#ecf0f1;border-left:4px solid #4a90e2;border-radius:4px;color:#34495e;font-style:italic;margin:20px 0;padding:15px 20px}.timeline{list-style:none;padding-left:0;position:relative}.timeline li{color:#2c3e50;margin-bottom:20px;padding-left:30px;position:relative}.timeline li:before{color:#4a90e2;content:"●";font-size:1.2em;left:0;position:absolute}.algorithm-box{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin:20px 0;padding:20px}.algorithm-box h4{color:#4a90e2;margin-bottom:15px;margin-top:0}.algorithm-box p{margin-bottom:10px}.algorithm-box ol,.algorithm-box ul{margin-bottom:15px;margin-left:25px}.algorithm-box li{margin-bottom:8px}.note{background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;margin-top:20px;padding:15px}.note,.note strong{color:#856404}dl{margin:20px 0}dt{color:#2c3e50;font-weight:600;margin-bottom:5px;margin-top:15px}dd{color:#34495e;margin-bottom:15px;margin-left:20px}a{color:#4a90e2;font-weight:500;text-decoration:none}a:hover{text-decoration:underline}.educational-footer{border-top:2px solid #ecf0f1;margin-top:50px;padding-top:30px;text-align:center}@media (max-width:768px){.educational-container{padding:20px}.educational-header h1{font-size:2em}.subtitle{font-size:1em}.educational-section h2{font-size:1.5em}.content-block{padding:15px}}.gallery-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.gallery-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;line-height:1.8;margin:0 auto;max-width:1200px;padding:40px}.back-button{background:#4a90e2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;margin-bottom:30px;padding:12px 24px;transition:background-color .3s ease}.back-button:hover{background:#357abd}.gallery-header{border-bottom:3px solid #4a90e2;margin-bottom:50px;padding-bottom:30px;text-align:center}.gallery-header h1{color:#2c3e50;font-size:2.5em;margin-bottom:10px}.subtitle{color:#7f8c8d;font-size:1.2em;font-style:italic}.gallery-section{margin-bottom:40px}.gallery-intro{background:#f8f9fa;border-left:4px solid #4a90e2;border-radius:8px;margin-bottom:30px;padding:25px}.gallery-intro p{color:#2c3e50;margin-bottom:15px}.gallery-note{background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;color:#856404;font-size:.9em;margin-top:20px;padding:15px}.gallery-note code{background:#ffffff80;border-radius:3px;font-family:Courier New,monospace;padding:2px 6px}.example-gallery{grid-gap:40px;display:grid;gap:40px;margin-top:20px}.example-item{margin-bottom:40px}.example-item h3{color:#2c3e50;font-size:1.5em;margin:0 0 25px;text-align:center}.split-image-container{background:#fff;border:2px solid #e6e6e6;border-radius:12px;box-shadow:0 4px 8px #00000014;overflow:hidden;width:100%}.split-image-wrapper{width:100%}.split-image-half,.split-image-wrapper{align-items:stretch;display:flex;position:relative}.split-image-half{flex:1 1;flex-direction:column;overflow:hidden}.split-image-half img{display:block;flex-shrink:0;height:auto;object-fit:contain;object-position:top center;width:100%}.before-half{background:#f8f9fa}.after-half{background:#f0f9f4}.split-label{background:#fffffff2;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#2c3e50;font-size:.85rem;font-weight:700;left:12px;letter-spacing:.02em;padding:6px 12px;position:absolute;top:12px;z-index:10}.after-half .split-label{background:#ecf9f0f2}.split-divider{background:linear-gradient(180deg,#4a90e2,#357abd);flex-shrink:0;position:relative;width:3px}.split-divider:before{background:#4a90e2;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;content:"";height:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}.gallery-footer{border-top:2px solid #ecf0f1;margin-top:50px;padding-top:30px;text-align:center}@media (max-width:768px){.gallery-container{padding:20px}.gallery-header h1{font-size:2em}.subtitle{font-size:1em}.split-image-wrapper{flex-direction:column}.split-divider{background:linear-gradient(90deg,#4a90e2,#357abd);height:3px;width:100%}.split-divider:before{left:50%;top:50%;transform:translate(-50%,-50%)}.split-label{font-size:.75rem;left:8px;padding:5px 10px;top:8px}}
/*# sourceMappingURL=main.f7bda370.css.map*/