*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #eef2ff;--secondary: #8b5cf6;--background: #ffffff;--background-subtle: #fafbfc;--surface: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e5e7eb;--border-light: #f3f4f6;--success: #059669;--success-light: #d1fae5;--error: #dc2626;--warning: #d97706;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .04);--shadow: 0 1px 3px 0 rgb(0 0 0 / .08), 0 1px 2px -1px rgb(0 0 0 / .08);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .08), 0 2px 4px -2px rgb(0 0 0 / .06);--shadow-lg: 0 10px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .08);--shadow-xl: 0 20px 40px -10px rgb(0 0 0 / .15), 0 8px 16px -8px rgb(0 0 0 / .1);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--header-height: 72px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(180deg,#fff,#f8fafc);background-attachment:fixed;color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);padding:0 24px;height:var(--header-height);position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center}.header-content{max-width:1200px;width:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:flex-start;flex-direction:column}.logo-text{display:flex;flex-direction:column;gap:2px}.logo-text h1{font-size:1.75rem;font-weight:300;color:#d4af37;line-height:1.2;letter-spacing:.25em;text-transform:uppercase;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin-bottom:-2px}.logo-text span{font-size:.6875rem;color:#8b8b8b;font-weight:400;letter-spacing:.08em;font-style:italic;padding-left:2px}.main-content{flex:1;padding-top:var(--header-height)}.main-container{max-width:1200px;margin:0 auto;padding:32px 24px;width:100%}.golden-ratio-info{display:flex;align-items:center;gap:14px;padding:14px 18px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius);font-size:.8125rem;color:#64748b;margin-bottom:28px;border:1px solid #e2e8f0;box-shadow:var(--shadow-sm)}.golden-ratio-info svg{width:20px;height:20px;flex-shrink:0;color:#94a3b8}.golden-ratio-info strong{font-weight:600;color:#475569}.validation-message{padding:14px 18px;border-radius:var(--radius);font-size:.875rem;margin-bottom:20px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}.validation-message.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c;border:1px solid #fecaca}.validation-message.warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);color:#b45309;border:1px solid #fde68a}.validation-message.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#047857;border:1px solid #a7f3d0}.validation-message.success svg{animation:successPop .4s ease-out}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.validation-message svg{width:20px;height:20px;flex-shrink:0}.upload-section{margin-bottom:28px}.upload-zone{border:1px solid var(--border);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;background:var(--surface);transition:all .25s ease;position:relative;box-shadow:var(--shadow)}.upload-zone:hover{border-color:var(--primary);background:linear-gradient(135deg,#fafbff,#f5f7ff);box-shadow:var(--shadow-md),0 0 0 4px #6366f10f}.upload-zone.drag-over{border-color:var(--primary);background:linear-gradient(135deg,#eef2ff,#e0e7ff);transform:scale(1.005);box-shadow:var(--shadow-lg),0 0 0 4px #6366f11f}.upload-zone.has-images{padding:28px;background:linear-gradient(135deg,#fafbfc,#f5f6f8)}.upload-icon{width:72px;height:72px;margin:0 auto 20px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #6366f126}.upload-icon svg{width:36px;height:36px;color:var(--primary)}.upload-text h3{font-size:1.25rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.upload-text p{font-size:.9375rem;color:var(--text-secondary);margin-bottom:6px}.upload-text small{font-size:.8125rem;color:var(--text-muted);display:block;margin-top:4px}.upload-button{display:inline-flex;align-items:center;gap:8px;margin-top:20px;padding:14px 28px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:var(--radius);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #6366f140}.upload-button:hover{background:linear-gradient(135deg,#4f46e5,#4338ca);transform:translateY(-2px);box-shadow:0 6px 20px #6366f159}.upload-button svg{width:20px;height:20px}.hidden-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);white-space:nowrap;border:0}.image-thumbnails{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:16px}.thumbnail{position:relative;width:90px;height:90px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);flex-shrink:0;transition:transform .25s ease,box-shadow .25s ease,opacity .2s ease,border-color .2s ease;cursor:grab;border:2px solid transparent;background:#fff}.thumbnail:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-lg)}.thumbnail:active{cursor:grabbing}.thumbnail.dragging{opacity:.5;transform:scale(.95)}.thumbnail.drag-over{border-color:var(--primary);transform:scale(1.05);box-shadow:var(--shadow-lg),0 0 0 3px #6366f133}.thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.thumbnail-remove{position:absolute;top:6px;right:6px;width:24px;height:24px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;padding:0}.thumbnail:hover .thumbnail-remove{opacity:1}.thumbnail-remove:hover{background:var(--error);transform:scale(1.1)}.thumbnail-remove svg{width:12px;height:12px}.thumbnail-order{position:absolute;bottom:6px;left:6px;width:22px;height:22px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-size:.6875rem;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #6366f14d}.add-more-thumbnail{width:90px;height:90px;border:2px dashed var(--border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;background:var(--surface);flex-shrink:0}.add-more-thumbnail:hover{border-color:var(--primary);background:linear-gradient(135deg,#fafbff,#f0f3ff);transform:translateY(-2px)}.add-more-thumbnail svg{width:22px;height:22px;color:var(--text-muted);margin-bottom:4px}.add-more-thumbnail span{font-size:.6875rem;color:var(--text-muted);font-weight:500}.image-count{text-align:center;font-size:.875rem;color:var(--text-secondary)}.image-count strong{color:var(--primary);font-weight:600}.settings-panel{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.setting-group{background:var(--surface);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border-light);transition:all .25s ease}.setting-group:hover{box-shadow:var(--shadow-md);border-color:var(--border);transform:translateY(-2px)}.setting-group h4{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:14px}.setting-group select{width:100%;padding:12px 44px 12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-primary);background:var(--surface);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;transition:all .2s ease;font-weight:500}.setting-group select:hover{border-color:#cbd5e1;background-color:#fafbfc}.setting-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11f}.range-container{display:flex;flex-direction:column;gap:10px}.range-value{font-size:1rem;color:var(--text-primary);font-weight:600}input[type=range]{-webkit-appearance:none;width:100%;height:6px;background:linear-gradient(90deg,#e2e8f0,#cbd5e1);border-radius:3px;border:none;padding:0;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:50%;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 2px 8px #6366f14d}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 4px 12px #6366f166}input[type=range]::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:50%;cursor:pointer;border:none}.quality-indicator{display:flex;gap:8px;margin-top:10px}.quality-badge{padding:4px 10px;border-radius:6px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.quality-badge.high{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.quality-badge.medium{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.layout-info{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.layout-info strong{color:var(--primary);font-weight:600}.layout-info small{display:block;font-size:.75rem;color:var(--text-muted);margin-top:4px}.collage-section{background:var(--surface);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md);border:1px solid var(--border-light)}.collage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}.collage-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.collage-actions{display:flex;gap:12px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .25s ease}.btn-primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#4338ca);transform:translateY(-2px);box-shadow:0 6px 20px #6366f159}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--background-subtle);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border-light);border-color:#cbd5e1}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px}.collage-preview-container{display:flex;justify-content:center;align-items:center;min-height:420px;background:linear-gradient(145deg,#f8fafc,#f1f5f9,#e2e8f0);border-radius:var(--radius);overflow:hidden;position:relative;border:1px solid var(--border-light)}.collage-preview{position:relative;background:#fff;box-shadow:var(--shadow-xl);border-radius:6px;overflow:hidden;border:1px solid rgba(0,0,0,.08)}.collage-canvas{display:block;max-width:100%;max-height:500px;width:auto;height:auto;transition:opacity .3s ease}.collage-canvas.loading{opacity:.5}.empty-state{text-align:center;padding:60px 40px}.empty-state svg{width:80px;height:80px;color:var(--text-muted);margin-bottom:20px;opacity:.35}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.empty-state p{font-size:.875rem;color:var(--text-muted)}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius)}.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:20px;height:20px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.loading-overlay p{margin-top:16px;font-size:.875rem;color:var(--text-secondary);font-weight:500}.upload-zone.uploading{pointer-events:none;border-color:var(--primary);background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.upload-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}.upload-loading p{margin-top:16px;font-size:.9375rem;color:var(--primary);font-weight:500}.btn-loading{position:relative;pointer-events:none}.btn-spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}.btn-primary .btn-spinner{border-color:#ffffff4d;border-top-color:#fff}.btn-secondary .btn-spinner{border-color:var(--border);border-top-color:var(--text-primary)}.validation-message{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.thumbnail{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.collage-preview{animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn{position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(#ffffff26,#fff0);opacity:0;transition:opacity .2s ease}.btn:hover:not(:disabled):after{opacity:1}.quality-note{display:block;margin-top:8px;font-size:.75rem;color:var(--text-muted);font-style:italic}.footer{text-align:center;padding:28px 24px;color:var(--text-muted);font-size:.8125rem;background:var(--surface);border-top:1px solid var(--border-light);margin-top:auto}@media (max-width: 900px){.settings-panel{grid-template-columns:1fr 1fr}}@media (max-width: 640px){:root{--header-height: 64px}.header{padding:0 16px}.logo-text h1{font-size:1.375rem}.logo-text span{font-size:.75rem}.main-container{padding:20px 16px}.upload-zone{padding:32px 20px}.settings-panel{grid-template-columns:1fr}.collage-header{flex-direction:column;gap:16px;align-items:stretch}.collage-actions{width:100%}.collage-actions .btn{flex:1;justify-content:center}.thumbnail,.add-more-thumbnail{width:75px;height:75px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal-content{background:var(--surface);border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.image-editor{width:600px;max-width:90vw;display:flex;flex-direction:column}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.editor-header h3{margin:0;font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:4px 8px;line-height:1;transition:color .2s ease}.modal-close:hover{color:var(--text-primary)}.editor-canvas-container{position:relative;background:#1a1a1a;display:flex;align-items:center;justify-content:center;min-height:300px;max-height:400px;padding:20px}.editor-canvas{max-width:100%;max-height:360px;cursor:crosshair}.editor-controls{padding:16px 20px;display:flex;gap:20px;align-items:center;border-bottom:1px solid var(--border);flex-wrap:wrap;background:var(--background-subtle)}.control-group{display:flex;align-items:center;gap:10px}.control-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.control-group input[type=range]{width:100px}.control-group span{font-size:.875rem;font-weight:600;color:var(--text-primary);min-width:40px}.btn-small{padding:6px 12px;font-size:.8125rem}.editor-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px}.thumbnail-edit{position:absolute;top:6px;left:6px;width:24px;height:24px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;padding:0}.thumbnail:hover .thumbnail-edit{opacity:1}.thumbnail-edit:hover{background:var(--primary);transform:scale(1.1)}.thumbnail-edit svg{width:12px;height:12px}.thumbnail.has-edits:after{content:"";position:absolute;bottom:6px;right:6px;width:8px;height:8px;background:var(--primary);border-radius:50%;border:2px solid white}@media (max-width: 640px){.image-editor{width:100%;max-height:100vh;border-radius:0}.editor-canvas-container{min-height:200px;max-height:300px}.editor-controls{gap:12px}.control-group input[type=range]{width:80px}}
