@import"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #f8f7f4;--color-bg-warm: #f3f1ec;--color-surface: #ffffff;--color-surface-hover: #fafafa;--color-accent: #1a1a1a;--color-accent-soft: #2d2d2d;--color-accent-muted: rgba(26, 26, 26, .08);--color-primary: #c9a227;--color-primary-hover: #b8922a;--color-primary-dim: rgba(201, 162, 39, .12);--color-text: #1a1a1a;--color-text-secondary: #525252;--color-text-muted: #9ca3af;--color-border: #e8e5de;--color-border-subtle: #f0ede6;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .12);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}html,body{height:100%;overflow:hidden}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5;font-feature-settings:"ss01" on,"ss02" on;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}.app{height:100%;display:flex;flex-direction:column;background:var(--color-bg);overflow:hidden}.toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:var(--color-surface);border-bottom:1px solid var(--color-border);position:relative;flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:var(--space-md)}.toolbar-left svg{color:var(--color-primary)}.toolbar-left h1{font-family:"Instrument Serif",Georgia,serif;font-size:1.5rem;font-weight:400;letter-spacing:-.02em;color:var(--color-text)}.image-count{font-size:.75rem;font-weight:500;letter-spacing:.03em;color:var(--color-text-secondary);background:var(--color-bg);padding:var(--space-xs) var(--space-md);border-radius:100px;border:1px solid var(--color-border)}.toolbar-right{display:flex;align-items:center;gap:var(--space-md)}button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 18px;font-family:DM Sans,sans-serif;font-size:.8125rem;font-weight:500;letter-spacing:.01em;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out);position:relative;overflow:hidden}button:disabled{opacity:.4;cursor:not-allowed}button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.export-button-container{position:relative}.export-button{background:var(--color-accent);color:#fff;font-weight:600}.export-button:hover:not(:disabled){background:var(--color-accent-soft);transform:translateY(-1px);box-shadow:var(--shadow-md)}.export-button:active:not(:disabled){transform:translateY(0)}.export-dropdown{position:absolute;top:calc(100% + var(--space-sm));right:0;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;z-index:100;animation:dropdownFade .2s var(--ease-out)}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.export-dropdown button{width:100%;justify-content:flex-start;padding:12px var(--space-md);background:transparent;color:var(--color-text);border-radius:0;font-weight:400}.export-dropdown button svg{color:var(--color-text-muted);transition:color .15s}.export-dropdown button:hover{background:var(--color-bg)}.export-dropdown button:hover svg{color:var(--color-primary)}.export-dropdown button:not(:last-child){border-bottom:1px solid var(--color-border-subtle)}.clear-button{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.clear-button:hover:not(:disabled){background:#dc26260f;border-color:var(--color-danger);color:var(--color-danger)}.main-content{flex:1;display:flex;gap:0;overflow:hidden;min-height:0}.canvas-section{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg-warm);min-height:0}.canvas-container{flex:1;display:flex;justify-content:center;align-items:flex-start;overflow:auto;padding:var(--space-xl);min-height:0}.collage-canvas{border-radius:var(--radius-sm)}.canvas-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-md);color:var(--color-text-muted);font-size:.9375rem}.canvas-placeholder:before{content:"";width:64px;height:64px;background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);opacity:.6}.sidebar{width:320px;flex-shrink:0;background:var(--color-surface);border-left:1px solid var(--color-border);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.control-panel{padding:var(--space-lg)}.control-panel h3{font-family:"Instrument Serif",Georgia,serif;font-size:1.125rem;font-weight:400;letter-spacing:-.01em;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text)}.control-group{margin-bottom:var(--space-lg)}.control-label{display:block;font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:var(--space-sm);color:var(--color-text-secondary)}.select-input,.layout-select{width:100%;padding:10px 40px 10px 14px;font-family:DM Sans,sans-serif;font-size:.875rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s var(--ease-out);-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='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.select-input:hover,.layout-select:hover{border-color:var(--color-text-muted)}.select-input:focus,.layout-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-muted)}.layout-select-wrapper{position:relative}.layout-description{display:block;margin-top:var(--space-sm);font-size:.75rem;color:var(--color-text-muted);font-style:italic}.column-buttons,.orientation-buttons{display:flex;gap:2px;background:var(--color-bg);padding:3px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.column-button,.orientation-button{flex:1;padding:8px 12px;background:transparent;border:none;font-size:.8125rem;color:var(--color-text-secondary);border-radius:var(--radius-sm)}.column-button:hover,.orientation-button:hover{background:var(--color-surface);color:var(--color-text)}.column-button.active,.orientation-button.active{background:var(--color-accent);color:#fff;font-weight:600;box-shadow:var(--shadow-sm)}.orientation-button{display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.range-input{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;outline:none;margin-top:var(--space-sm)}.range-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;box-shadow:var(--shadow-md);transition:transform .15s var(--ease-spring)}.range-input::-webkit-slider-thumb:hover{transform:scale(1.15)}.range-input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;border:none;box-shadow:var(--shadow-md)}.custom-size-inputs{display:flex;align-items:flex-end;gap:var(--space-sm);margin-top:var(--space-md)}.size-input-group{flex:1}.size-input-group label{display:block;font-size:.6875rem;color:var(--color-text-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.number-input{width:100%;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:.875rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all .15s var(--ease-out)}.number-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-muted)}.size-separator{padding-bottom:10px;color:var(--color-text-muted);font-size:.875rem}.image-uploader{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-md);padding:var(--space-md);background:var(--color-bg);border:1px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s var(--ease-out)}.image-uploader:hover{border-color:var(--color-accent);background:var(--color-accent-muted)}.image-uploader.loading{pointer-events:none;opacity:.6}.uploader-visual{flex-shrink:0}.uploader-icon-ring{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all .2s var(--ease-out)}.image-uploader:hover .uploader-icon-ring{background:var(--color-accent);border-color:var(--color-accent)}.uploader-icon-ring svg{color:var(--color-text-secondary);transition:color .2s}.image-uploader:hover .uploader-icon-ring svg{color:#fff}.uploader-spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.uploader-text{display:flex;flex-direction:column;gap:2px}.uploader-title{font-size:.875rem;font-weight:500;color:var(--color-text)}.uploader-hint{font-size:.75rem;color:var(--color-text-muted)}.image-tile{cursor:grab;overflow:hidden;transition:transform .15s var(--ease-out),box-shadow .15s var(--ease-out)}.image-tile:hover{z-index:10}.image-tile:active{cursor:grabbing}.image-tile-overlay{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;padding:var(--space-sm);background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,transparent 100%);opacity:0;transition:opacity .2s var(--ease-out)}.image-tile:hover .image-tile-overlay{opacity:1}.tile-button{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--color-text);border-radius:var(--radius-sm);transition:all .15s var(--ease-out)}.tile-button:hover{background:#fff;transform:scale(1.05)}.remove-button:hover{background:var(--color-danger);color:#fff}.drag-handle{cursor:grab}.drag-handle:active{cursor:grabbing}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-size-selector{margin-bottom:var(--space-lg)}.custom-grid-container{touch-action:none}.grid-image-tile{cursor:default;-webkit-user-select:none;user-select:none}.grid-remove-button{position:absolute;top:8px;right:8px;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:#000000b3;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:opacity .15s,background .15s;z-index:10}.grid-image-tile:hover .grid-remove-button{opacity:1}.grid-remove-button:hover{background:var(--color-danger)}.grid-size-badge{position:absolute;bottom:8px;right:8px;padding:2px 8px;font-size:.6875rem;font-weight:600;color:#fff;background:#0009;border-radius:var(--radius-sm);pointer-events:none;opacity:0;transition:opacity .15s}.grid-image-tile:hover .grid-size-badge{opacity:1}.resize-handle{position:absolute;background:transparent;z-index:10}.resize-handle:after{content:"";position:absolute;background:var(--color-accent);border-radius:2px;opacity:0;transition:opacity .15s}.grid-image-tile:hover .resize-handle:after{opacity:.8}.resize-handle-right{top:10%;right:0;width:12px;height:80%;cursor:ew-resize}.resize-handle-right:after{top:50%;right:2px;width:4px;height:40px;transform:translateY(-50%)}.resize-handle-bottom{bottom:0;left:10%;width:80%;height:12px;cursor:ns-resize}.resize-handle-bottom:after{bottom:2px;left:50%;width:40px;height:4px;transform:translate(-50%)}.resize-handle-corner{bottom:0;right:0;width:20px;height:20px;cursor:nwse-resize}.resize-handle-corner:after{bottom:4px;right:4px;width:10px;height:10px;border-radius:50%}@media (max-width: 900px){.main-content{flex-direction:column}.canvas-section{flex:1;min-height:300px}.canvas-container{padding:var(--space-md)}.sidebar{width:100%;flex-shrink:0;max-height:50vh;border-left:none;border-top:1px solid var(--color-border)}.toolbar{padding:var(--space-md)}.toolbar-left h1{font-size:1.25rem}}@media (max-width: 600px){.toolbar-left h1{display:none}.toolbar-right{gap:var(--space-sm)}.clear-button span{display:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
