@font-face{font-family:Roboto;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/roboto-latin-400-normal-BqEyEoaF.woff2) format("woff2"),url(/assets/roboto-latin-400-normal-DyYNIH4P.woff) format("woff")}@font-face{font-family:Roboto;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/roboto-latin-500-normal-7RbcRiD8.woff2) format("woff2"),url(/assets/roboto-latin-500-normal-DQZyH_nt.woff) format("woff")}@font-face{font-family:Roboto;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/roboto-latin-700-normal-BZpUvMxY.woff2) format("woff2"),url(/assets/roboto-latin-700-normal-DLgJJpmK.woff) format("woff")}@font-face{font-family:Playwrite US Trad;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/playwrite-us-trad-latin-400-normal-CJ8VfeJg.woff2) format("woff2"),url(/assets/playwrite-us-trad-latin-400-normal-B6GuHySI.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{color-scheme:light;font-family:Roboto,Segoe UI,Arial,sans-serif;line-height:1.5;font-weight:400;color:#18201b;background:#f3f1ec;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--surface: #ffffff;--surface-strong: #fcfbf8;--border: #d9ddd5;--accent: #1f3b2d;--accent-soft: #4a5f53;--highlight: #d9a24d;--danger: #9e2f2f;--text-soft: #5d685f;--shadow: 0 12px 32px rgba(33, 43, 36, .08)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.65}.app-shell{min-height:100vh;padding:28px 20px 40px}.app{width:min(1180px,100%);margin:0 auto}.hero,.site-intro{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.9fr);gap:20px;margin-bottom:20px}.site-intro-copy,.hero-copy-block{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}.brand-mark{width:84px;height:84px;border-radius:22px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);display:grid;place-items:center;flex-shrink:0}.brand-mark img{width:64px;height:64px;display:block}.hero h1{margin:0;font-size:clamp(2rem,4vw,3.4rem);line-height:1.02;max-width:12ch}.hero-copy{max-width:52ch;margin:14px 0 0;color:var(--text-soft);font-size:1rem}.hero-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.hero-tag{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--border);background:#faf8f3;color:var(--accent);font-size:.88rem;font-weight:500}.hero-card,.panel,.message{background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.hero-card{padding:18px;align-self:end}.tool-switcher{display:grid;gap:12px;align-self:end}.tool-switch-button{min-height:60px;border-radius:16px;border:1px solid var(--border);background:#fff;color:var(--accent);text-align:left;padding:0 18px;font-weight:700;box-shadow:var(--shadow)}.tool-switch-button.is-active{background:var(--accent);color:#fffdf8;border-color:var(--accent)}.hero-stat-label,.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--text-soft)}.hero-stat{margin:0;font-size:1.1rem;font-weight:700}.layout-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.9fr);gap:18px;align-items:start}.left-column,.right-column{display:grid;gap:20px;align-content:start}.panel{padding:18px}.panel-heading{display:flex;justify-content:space-between;gap:12px;align-items:start;margin-bottom:18px}.panel-heading h2{margin:0;font-size:1.1rem}.panel-heading-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.file-badge,.dimension-badge{padding:8px 12px;border-radius:999px;background:#f5ebd8;color:var(--accent);font-size:.86rem;font-weight:600}.upload-dropzone{display:grid;place-items:center;gap:8px;min-height:190px;padding:24px;border:2px dashed #c3cdc2;border-radius:16px;background:#faf8f3;text-align:center;transition:transform .16s ease,border-color .16s ease,background .16s ease}.upload-dropzone:hover,.upload-dropzone:focus-within,.upload-dropzone.is-dragging{transform:translateY(-1px);border-color:#8da08f;background:#f6f1e6}.upload-dropzone.is-disabled{pointer-events:none}.upload-title{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 16px;border-radius:999px;background:var(--accent);color:#fffdf8;font-weight:700}.upload-copy,.helper-text{margin:0;color:var(--text-soft);font-size:.94rem}.section-helper-text{margin-top:14px}.panel-description{margin-top:16px;margin-bottom:18px;line-height:1.6}.panel-description-tight{margin-bottom:0}.preview-footer{display:grid;gap:8px}.preview-desktop-note{color:var(--accent-soft);margin-top:-2px}.preview-shell{position:relative;overflow:hidden;border-radius:14px;background:linear-gradient(45deg,rgba(24,32,27,.05) 25%,transparent 25%),linear-gradient(-45deg,rgba(24,32,27,.05) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(24,32,27,.05) 75%),linear-gradient(-45deg,transparent 75%,rgba(24,32,27,.05) 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0;border:1px solid var(--border)}.preview-shell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;box-shadow:inset 0 0 0 1px #fffcf6d1;pointer-events:none}.preview-dropzone-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.preview-dropzone{position:absolute;display:grid;place-items:center;border-radius:16px;border:2px dashed rgba(31,59,45,.18);background:#ffffff0a;color:transparent;pointer-events:auto;cursor:grab;transition:left .18s ease,top .18s ease,width .18s ease,height .18s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}.preview-dropzone:hover,.preview-dropzone.is-hovered{border-color:#1f3b2d5c;background:#1f3b2d0d}.preview-dropzone.is-dragging{opacity:.55;transform:scale(.985);cursor:grabbing}.preview-dropzone.is-selected{border-color:#1f3b2d73;box-shadow:inset 0 0 0 2px #fffcf6d6}.preview-dropzone.is-drop-target{border-color:#d9a24de6;background:#d9a24d2e;box-shadow:inset 0 0 0 2px #fff8ecbf,0 0 0 3px #d9a24d29;animation:preview-drop-pulse 1.2s ease-in-out infinite}.preview-dropzone-label{padding:6px 10px;border-radius:999px;background:#fffcf6eb;color:var(--accent);font-size:.78rem;font-weight:700;opacity:0;transition:opacity .14s ease}.preview-dropzone:hover .preview-dropzone-label,.preview-dropzone.is-hovered .preview-dropzone-label,.preview-dropzone.is-drop-target .preview-dropzone-label{opacity:1}@keyframes preview-drop-pulse{0%,to{box-shadow:inset 0 0 0 2px #fff8ecbf,0 0 0 3px #d9a24d1f}50%{box-shadow:inset 0 0 0 2px #fff8ece6,0 0 0 6px #d9a24d2e}}.preview-panel{align-self:start}.preview-canvas{display:block;width:100%;height:auto;max-height:72vh;object-fit:contain}.preview-canvas.is-hidden{display:none}.preview-placeholder{min-height:300px;display:grid;place-items:center;padding:28px;text-align:center;color:var(--text-soft)}.thumb-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.thumb-card{display:grid;gap:8px;padding:10px;border-radius:18px;border:1px solid var(--border);background:#fdfbf6;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;transition:border-color .14s ease,transform .14s ease,box-shadow .14s ease}.thumb-card.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px #1f3b2d1f}.thumb-card.is-dragging{opacity:.78;transform:scale(.98)}.thumb-card.is-drop-target{border-color:#7b5a17;box-shadow:0 0 0 2px #7b5a171f}.thumb-image{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;border:1px solid var(--border);background:#f4f1ea}.thumb-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.thumb-order,.thumb-drag-hint{font-size:.78rem;color:var(--text-soft)}.thumb-order{font-weight:700;color:var(--accent)}.thumb-label{margin:0;color:var(--text);font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thumb-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.arrange-panel{display:grid;gap:12px;margin-top:18px;padding:14px;border-radius:16px;border:1px solid var(--border);background:#faf8f3}.arrange-title{margin:4px 0 0;font-weight:700}.arrange-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.thumb-action-button{min-height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--accent);padding:0 12px;font-size:.85rem}.thumb-action-button.is-danger{color:var(--danger)}.layout-choice-group{margin:0;padding:0;border:0}.output-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.output-choice-card{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center;min-height:88px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--accent);text-align:left}.output-choice-card.is-active{border-color:var(--accent);background:#f6f1e6}.output-preview{display:block;justify-self:center;align-self:center;border-radius:12px;border:2px solid #d1d8cf;background:linear-gradient(135deg,#1f3b2d0f,#1f3b2d03),#f8f4ec;box-shadow:inset 0 0 0 1px #ffffffd9,inset 0 10px 18px #ffffff3d}.output-preview-square{width:56px;height:56px}.output-preview-portrait{width:46px;height:58px}.output-preview-story{width:34px;height:62px}.choice-cards{display:grid;gap:10px}.choice-card{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center;min-height:88px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--accent);text-align:left}.choice-card-copy{display:grid;gap:4px}.choice-card strong{font-size:.96rem}.choice-card-copy span{color:var(--text-soft);font-size:.88rem}.choice-card.is-active{border-color:var(--accent);background:#f6f1e6}.layout-preview{display:grid;gap:4px;width:72px;height:72px;padding:4px;border-radius:14px;background:#f5f0e5;border:1px solid #e1d6c0}.layout-preview span{display:block;border-radius:8px;background:#d8ddd4}.layout-preview .is-main{background:#d9a24d}.layout-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.layout-preview-2x2{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr))}.layout-preview-2x2 .is-main{grid-column:span 2;grid-row:span 2}.layout-preview-2x1{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr))}.layout-preview-2x1 .is-main{grid-column:span 2}.layout-preview-1x2{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr))}.layout-preview-1x2 .is-main{grid-row:span 2}.controls-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.field{display:grid;gap:8px}.field-full{grid-column:1 / -1}.field span,.toggle-row legend{font-weight:600}.field input[type=text],.field input[type=color],.field select{min-height:48px;border-radius:12px;border:1px solid var(--border);background:var(--surface-strong);color:inherit;padding:0 14px}.preset-panel{padding-bottom:6px;border-bottom:1px solid var(--border)}.preset-save-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.preset-save-row input{min-height:48px;border-radius:12px;border:1px solid var(--border);background:var(--surface-strong);color:inherit;padding:0 14px}.preset-list{display:grid;gap:10px}.preset-chip{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#faf8f3}.preset-apply-button{min-height:42px;padding:0 14px;text-align:left;justify-content:flex-start;width:100%}.preset-delete-button{min-height:42px;border:0;background:transparent;color:var(--text-soft);padding:0 8px;font-weight:500}.collage-summary{padding:14px 16px;border-radius:14px;background:#f9f6ef;border:1px solid var(--border)}.collage-warning{padding:14px 16px;border-radius:14px;background:#fff5e7;border:1px solid #efd0a2}.warning-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.warning-action-button{min-height:40px;padding:0 14px;background:#fff}.field input[type=color]{padding:6px}.field input[type=range]{width:100%;accent-color:#7b5a17}.toggle-row{display:flex;flex-wrap:wrap;gap:10px 16px;margin:0;padding:0;border:0}.check-field{display:inline-flex;align-items:center;gap:10px;min-height:44px;padding:10px 14px;border-radius:12px;background:#f7f5ef;border:1px solid var(--border)}.check-field input{width:18px;height:18px}.export-actions{display:grid;gap:12px}.primary-button,.secondary-button,.ghost-button{min-height:52px;border-radius:14px;padding:0 18px;border:1px solid transparent;font-weight:700}.primary-button{background:var(--accent);color:#fffdf8}.secondary-button{background:#f5ebd8;color:var(--accent);border-color:#ead5b1}.ghost-button{background:#fff;color:var(--accent);border-color:var(--border)}.message{margin-bottom:18px;padding:14px 18px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#0f13107a;z-index:50}.modal-card{width:min(460px,100%);padding:22px;border-radius:20px;border:1px solid var(--border);background:var(--surface);box-shadow:0 18px 48px #0000002e}.modal-card h2{margin:0 0 10px;font-size:1.2rem}.modal-card p{margin:0;color:var(--text-soft)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.site-footer{width:min(1180px,100%);margin:18px auto 0}.site-footer-card{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 18px;border-radius:18px;background:linear-gradient(180deg,#f8f5ee,#f2eee4);border:1px solid var(--border);box-shadow:var(--shadow)}.site-footer-brand{display:flex;align-items:center;gap:14px;min-width:0}.site-footer-brand img{width:44px;height:44px;border-radius:12px;flex-shrink:0}.site-footer-title{margin:0;font-weight:700;color:var(--accent)}.site-footer-copy,.site-footer-meta{margin:2px 0 0;color:var(--text-soft);font-size:.92rem}.site-footer-meta{margin:0;text-align:right}.status-message{color:var(--accent)}.error-message{color:var(--danger)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 920px){.app-shell{padding:16px}.hero-copy-block,.site-intro-copy,.site-intro,.hero,.layout-grid{grid-template-columns:1fr}}@media (min-width: 921px){.preview-panel{position:sticky;top:20px}}@media (max-width: 640px){.controls-grid,.output-choice-grid,.preset-save-row{grid-template-columns:1fr}.panel,.hero-card{border-radius:16px}.panel-heading{flex-direction:column}.panel-heading-actions{width:100%;justify-content:stretch}.panel-heading-actions>*{flex:1 1 0}.preview-placeholder{min-height:220px}.thumb-list{grid-template-columns:1fr}.preview-dropzone-layer{display:none}.thumb-meta{flex-direction:column;align-items:flex-start}.arrange-actions{grid-template-columns:1fr}.site-footer-card,.site-footer-brand{flex-direction:column;align-items:flex-start}.site-footer-meta{text-align:left}}
