*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.result-image{position:relative;aspect-ratio:1/1;background-size:contain;background-position:center;background-repeat:no-repeat;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;transition:transform var(--transition-normal),box-shadow var(--transition-normal);box-shadow:var(--shadow-sm);cursor:pointer}.result-image img{width:100%;height:100%;-o-object-position:center;object-position:center;display:block;-webkit-touch-callout:default;-webkit-user-select:auto;-moz-user-select:auto;user-select:auto;pointer-events:auto;touch-action:auto}.layout-2-persons{display:grid;grid-template-rows:1fr 1fr;gap:.75rem;margin-bottom:1rem}.layout-3-persons{display:grid;grid-template-areas:"top top" "left right";grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.layout-3-persons .left{grid-area:left;margin-left:auto;margin-right:.375rem;width:auto;max-width:200px}.layout-3-persons .right{grid-area:right;margin-right:auto;margin-left:.375rem;width:auto;max-width:200px}.layout-5-persons{display:grid;grid-template-areas:"topleft topright" "bottom bottom";grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.layout-5-persons .topleft{grid-area:topleft;justify-self:end;margin-right:.375rem}.layout-5-persons .topright{grid-area:topright;justify-self:start;margin-left:.375rem}.layout-5-persons .bottom{grid-area:bottom;display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;max-width:600px;margin:0 auto;width:100%}@media (max-width: 640px){.layout-5-persons .topleft,.layout-5-persons .topright{max-width:120px}.layout-5-persons .bottom{max-width:100%}.layout-3-persons .top{width:50%}}@media (max-width: 400px){.layout-5-persons .topleft,.layout-5-persons .topright{max-width:100px}.layout-3-persons .top{width:60%}}.layout-7-persons{display:grid;grid-template-areas:"top top top" "middle middle middle" "bottom bottom bottom";gap:.75rem;margin-bottom:1rem}.layout-7-persons .middle,.layout-7-persons .bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.layout-8-persons{display:grid;grid-template-areas:"top top" "middle middle" "bottom bottom";gap:.75rem;margin-bottom:1rem}.layout-8-persons .top{grid-area:top;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;width:66%;margin:0 auto}.layout-8-persons .middle,.layout-8-persons .bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}@font-face{font-family:KaitiLocal;src:local("Kaiti"),local("楷体"),local("STKaiti"),local("华文楷体");font-weight:400;font-style:normal;font-display:swap}:root{--primary-color: #7B9E89;--accent-color: #E8C4C4;--text-color: #333333;--text-secondary: #777777;--bg-color: #F9F3E5;--card-bg: #FFFFFF;--border-color: #DDDDDD;--success-color: #7B9E89;--error-color: #E88C8C;--warning-color: #FFD166;--font-decorative: "Dancing Script", cursive;--font-body: "Noto Sans SC", "KaitiLocal", "Kaiti", "楷体", "STKaiti", "华文楷体", Arial, "PingFang SC", "微软雅黑", sans-serif;--font-note: "KaitiLocal", "Kaiti", "楷体", "STKaiti", "华文楷体", var(--font-body);--breakpoint-xs: 375px;--breakpoint-sm: 430px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1366px;--content-max-width-sm: 450px;--content-max-width-md: 600px;--content-max-width-lg: 900px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--note-bg-1: linear-gradient(to right bottom, #FFFFFF, #F9F3E5);--note-bg-2: linear-gradient(to right bottom, #FFF9F9, #FFE8E8);--note-bg-3: linear-gradient(to right bottom, #F0F8FF, #E6F0F9);--note-bg-4: linear-gradient(to right bottom, #F5FFF5, #E6F9E6)}body.dark-mode{--primary-color: #8DB39E;--accent-color: #E8C4C4;--text-color: #E0E0E0;--text-secondary: #A0A0A0;--bg-color: #1A1A1A;--card-bg: #2C2C2C;--border-color: #444444;--success-color: #8DB39E;--error-color: #E88C8C;--warning-color: #FFD166;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3);--note-bg-1: linear-gradient(to right bottom, #3C3C3C, #444444);--note-bg-2: linear-gradient(to right bottom, #3E3839, #463B3C);--note-bg-3: linear-gradient(to right bottom, #373D40, #394249);--note-bg-4: linear-gradient(to right bottom, #384038, #3F4A3F)}*{margin:0;padding:0;box-sizing:border-box;transition:background-color .1s ease,color .1s ease,border-color .1s ease,box-shadow .1s ease}body{font-family:var(--font-body);color:var(--text-color);background-color:var(--bg-color);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;max-width:var(--content-max-width-sm);margin:0 auto;padding:var(--spacing-md)}.page-container{width:100%;max-width:100%;margin:0 auto;display:flex;flex-direction:column;min-height:100vh}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-body);font-size:16px;font-weight:500;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;white-space:nowrap}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:transparent;border:1px solid var(--primary-color);color:var(--primary-color)}.btn-secondary:hover{background-color:#7b9e890d}.card{background-color:var(--card-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-secondary);font-family:var(--font-note)}.form-input,select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-body);font-size:16px;transition:border-color var(--transition-fast);background-color:var(--card-bg);color:var(--text-color)}.form-input:focus,select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #7b9e891a}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23777' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:16px;padding-right:32px}.app-header{text-align:center;padding:var(--spacing-lg) 0;background:var(--note-bg-1);border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.app-title{font-family:var(--font-note);font-size:28px;color:var(--primary-color);margin-bottom:var(--spacing-sm)}.app-subtitle{font-family:var(--font-note);font-size:16px;color:var(--text-secondary)}.main-content{padding:var(--spacing-md);max-width:var(--content-max-width-sm);margin:0 auto}.image-select-area{margin-bottom:var(--spacing-lg)}.upload-btn-wrapper{position:relative;overflow:hidden;display:flex;justify-content:center;width:100%;margin-bottom:var(--spacing-md)}.upload-btn{background-color:var(--primary-color);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);width:80%;max-width:300px}.upload-btn:hover{background-color:#6a8d78;transform:translateY(-2px);box-shadow:var(--shadow-md)}.upload-btn-wrapper input[type=file]{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}.default-images-drawer{background-color:var(--card-bg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);overflow:hidden;transition:max-height var(--transition-normal);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:#7b9e891a;cursor:pointer}.drawer-title{font-family:var(--font-note);color:var(--primary-color);font-size:16px;font-weight:500;margin-right:auto}.drawer-subtitle{font-size:12px;color:#888;margin-right:10px}.drawer-icon{width:20px;height:20px;transition:transform var(--transition-normal)}.drawer-icon.open{transform:rotate(180deg)}.drawer-content{overflow:hidden;max-height:0;transition:max-height var(--transition-normal)}.drawer-content.open{max-height:500px}.default-images-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);padding:var(--spacing-md)}.default-image-item{position:relative;aspect-ratio:1/1;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-color);transition:all var(--transition-normal)}.default-image-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.default-image-item.selected{border:2px solid var(--primary-color);box-shadow:0 0 0 3px #7b9e894d}.default-image-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--transition-fast)}.default-image-item:hover img{transform:scale(1.05)}.preview-container{margin-bottom:var(--spacing-lg)}.preview-area{width:100%;aspect-ratio:1/1;background-color:var(--card-bg);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px dashed var(--border-color);margin-bottom:var(--spacing-md)}.preview-placeholder{color:var(--text-secondary);font-family:var(--font-note);text-align:center;padding:var(--spacing-md)}.preview-image{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.generate-btn{width:100%;background-color:var(--primary-color);color:#fff;padding:var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-note);font-size:18px;border:none;cursor:pointer;transition:all var(--transition-normal);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.generate-btn:hover{background-color:#6a8d78;transform:translateY(-2px);box-shadow:var(--shadow-md)}.results-container{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.results-title{font-family:var(--font-note);color:var(--primary-color);font-size:22px;margin-bottom:var(--spacing-lg);text-align:center}.results-hint{text-align:center;margin:10px 0;font-size:14px;color:var(--text-muted-color)}.special-layout-hint{text-align:center;margin:10px 0;padding:10px 15px;font-size:14px;color:var(--accent-color);font-weight:500;font-family:var(--font-note);background-color:#e8c4c41a;border-radius:var(--radius-md);border-left:3px solid var(--accent-color);animation:fadeOut .5s 5s forwards}.crop-hint{text-align:center;margin:8px 0;padding:6px 12px;font-size:14px;font-family:var(--font-note);color:var(--primary-color);border-radius:var(--radius-md);background-color:#7b9e891a;transition:all var(--transition-normal)}@keyframes fadeOut{0%{opacity:1}to{opacity:0;visibility:hidden}}.result-image{position:relative;aspect-ratio:1/1;background-size:contain;background-position:center;background-repeat:no-repeat;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;transition:transform var(--transition-normal),box-shadow var(--transition-normal);box-shadow:var(--shadow-sm)}.result-image:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);z-index:1}.result-image img{width:100%;height:100%;-o-object-position:center;object-position:center;display:block}.layout-4-persons .result-image img,.layout-6-persons .result-image img,.layout-9-persons .result-image img{-o-object-fit:cover;object-fit:cover}.layout-3-persons .top img{-o-object-fit:contain;object-fit:contain}.layout-3-persons .left img,.layout-3-persons .right img{-o-object-fit:cover;object-fit:cover}.layout-5-persons .topleft img,.layout-5-persons .topright img{-o-object-fit:contain;object-fit:contain}.layout-5-persons .bottom .result-image img{-o-object-fit:cover;object-fit:cover}.layout-2-persons{display:grid;grid-template-rows:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-3-persons{display:grid;grid-template-areas:"top top" "left right";grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-3-persons .top{grid-area:top;width:33%;max-width:200px;margin:0 auto}.layout-3-persons .left{grid-area:left;margin-left:auto;margin-right:calc(var(--spacing-md) / 2);width:auto;max-width:200px}.layout-3-persons .right{grid-area:right;margin-right:auto;margin-left:calc(var(--spacing-md) / 2);width:auto;max-width:200px}.layout-5-persons{display:grid;grid-template-areas:"topleft topright" "bottom bottom";grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-5-persons .topleft,.layout-5-persons .topright{justify-self:center;width:100%;max-width:150px;align-self:center}.layout-5-persons .topleft{grid-area:topleft;justify-self:end;margin-right:calc(var(--spacing-md) / 2)}.layout-5-persons .topright{grid-area:topright;justify-self:start;margin-left:calc(var(--spacing-md) / 2)}.layout-5-persons .bottom{grid-area:bottom;display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md);max-width:600px;margin:0 auto;width:100%}.layout-7-persons{display:grid;grid-template-areas:"top top top" "middle middle middle" "bottom bottom bottom";gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-7-persons .top{grid-area:top;margin:0 auto;width:33%}.layout-7-persons .middle,.layout-7-persons .bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md)}.layout-7-persons .middle{grid-area:middle}.layout-7-persons .bottom{grid-area:bottom}.layout-8-persons{display:grid;grid-template-areas:"top top" "middle middle" "bottom bottom";gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-8-persons .top{grid-area:top;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);width:66%;margin:0 auto}.layout-8-persons .middle,.layout-8-persons .bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md)}.layout-8-persons .middle{grid-area:middle}.layout-8-persons .bottom{grid-area:bottom}.action-buttons{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.download-all-btn{background-color:var(--primary-color);color:#fff;padding:var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-note);font-size:16px;border:none;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center}.download-all-btn:hover{background-color:#6a8d78;transform:translateY(-2px);box-shadow:var(--shadow-md)}.reset-btn{background-color:var(--text-secondary);color:#fff;padding:var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-note);font-size:16px;border:none;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center}.reset-btn:hover{background-color:#666;transform:translateY(-2px);box-shadow:var(--shadow-md)}.app-footer{text-align:center;padding:var(--spacing-lg);color:var(--text-secondary);font-size:14px;margin-top:var(--spacing-xl);border-top:1px solid var(--border-color);background-color:var(--bg-color)}.loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(123,158,137,.3);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.container{padding:var(--spacing-sm)}.app-title{font-size:24px}.default-images-grid{grid-template-columns:repeat(2,1fr)}.btn{padding:var(--spacing-sm) var(--spacing-md);font-size:15px}.form-input,select{font-size:15px;padding:var(--spacing-xs) var(--spacing-sm)}.layout-5-persons .topleft,.layout-5-persons .topright{max-width:120px}.layout-5-persons .bottom{max-width:100%}.layout-3-persons .top{width:50%}}@media (max-width: 375px){.container{padding:var(--spacing-xs) var(--spacing-sm)}.card{padding:var(--spacing-md)}.app-title{font-size:22px}.layout-5-persons .topleft,.layout-5-persons .topright{max-width:100px}.layout-3-persons .top{width:60%}}@media (min-width: 768px){.container{padding:var(--spacing-lg);max-width:var(--content-max-width-md)}.app-title{font-size:32px}.default-images-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.container{max-width:var(--content-max-width-md)}.card{padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}}.app-credit{font-family:var(--font-note);font-size:14px;color:var(--text-secondary);margin-top:var(--spacing-sm)}.app-credit a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}.app-credit a:hover{color:#6a8d78;text-decoration:underline}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-md)}.footer-btn{background-color:transparent;border:1px solid var(--primary-color);color:var(--primary-color);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-note);font-size:14px;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.footer-btn:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal);pointer-events:none}.modal.active{opacity:1;visibility:visible;pointer-events:all}.modal-content{background-color:var(--card-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);max-width:90%;max-height:90%;overflow:auto;position:relative;box-shadow:var(--shadow-lg);transform:scale(.9);transition:transform var(--transition-normal)}.modal.active .modal-content{transform:scale(1)}.close-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:24px;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{color:var(--error-color);background-color:#0000000d}.modal-title{font-family:var(--font-note);color:var(--primary-color);font-size:20px;margin-bottom:var(--spacing-md);text-align:center}.modal-body{display:flex;flex-direction:column;align-items:center}.modal-image{max-width:100%;height:auto;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}@media (max-width: 480px){.footer-links{flex-direction:column;gap:var(--spacing-sm)}.footer-btn{width:100%}.modal-content{padding:var(--spacing-md)}}.hidden{display:none!important;visibility:hidden!important}.layout-4-persons{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-6-persons{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.layout-9-persons{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}#previewImage{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.selected-default-image{border:3px solid #3b82f6}.preview-image-container{position:relative;width:100%;max-width:300px;margin:0 auto}.preview-image{max-width:100%;max-height:300px;display:block;margin:0 auto}.cropper-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.cropper-box{position:absolute;border:2px dashed var(--primary-color);background-color:#7b9e8933;cursor:move;pointer-events:auto;box-shadow:0 0 0 9999px #00000080;touch-action:none}.cropper-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0006;pointer-events:none}.cropper-box:before,.cropper-box:after{content:"";position:absolute;width:10px;height:10px;background-color:var(--primary-color);border-radius:50%}.cropper-box:before{top:-5px;left:-5px}.cropper-box:after{bottom:-5px;right:-5px}.cropper-controls{display:flex;flex-direction:column;align-items:center;margin-top:10px;gap:10px}.cropper-hint{font-size:14px;color:var(--text-muted-color);margin-bottom:5px}.confirm-crop-btn,.reset-crop-btn,.cropper-ratio-btn{padding:8px 16px;border-radius:var(--radius-md);border:none;font-weight:500;cursor:pointer;transition:all var(--transition-normal);width:100%;max-width:300px}.confirm-crop-btn{background-color:var(--primary-color);color:#fff}.confirm-crop-btn:hover{background-color:#6a8d78}.reset-crop-btn{background-color:var(--secondary-bg-color);color:var(--text-color)}.reset-crop-btn:hover{background-color:#e0e0e0}.cropper-ratio-btn{background-color:var(--accent-color);color:#333;margin-top:8px;padding:10px 16px;font-family:var(--font-note);box-shadow:var(--shadow-sm)}.cropper-ratio-btn:hover{background-color:#ddb3b3;transform:translateY(-1px);box-shadow:var(--shadow-md)}.ratio-description{margin-top:5px;font-size:13px;font-family:var(--font-note);color:var(--text-secondary);font-style:italic;text-align:center}.cropper-resize-handle{position:absolute;width:14px;height:14px;background-color:var(--primary-color);border:2px solid white;border-radius:50%;z-index:10;box-shadow:0 0 3px #0000004d;touch-action:none}.cropper-resize-handle:hover{transform:scale(1.2)}.cropper-resize-handle.bottom-right{right:-7px;bottom:-7px;cursor:nwse-resize}.cropper-resize-handle.bottom-left{left:-7px;bottom:-7px;cursor:nesw-resize}.cropper-resize-handle.top-right{right:-7px;top:-7px;cursor:nesw-resize}.cropper-resize-handle.top-left{left:-7px;top:-7px;cursor:nwse-resize}.color-block-drawer{margin-top:10px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.color-block-drawer .drawer-content{overflow:hidden;max-height:0;transition:max-height var(--transition-normal);background-color:#f9f9f9}.color-block-drawer .drawer-content.open{max-height:500px}.color-drawer-hint{padding:10px var(--spacing-md) 0;font-size:14px;color:#666;margin-bottom:10px;text-align:center;line-height:1.4}.color-picker-container{display:flex;align-items:center;margin-bottom:15px;padding:var(--spacing-md)}.color-preview{width:40px;height:40px;border-radius:8px;background-color:#fff;border:1px solid #e0e0e0;margin-right:10px}#colorPicker{height:40px;padding:5px;border:1px solid #e0e0e0;border-radius:8px;margin-right:10px;cursor:pointer}.color-picker-wrapper{position:relative;margin-right:10px}.color-picker-icon{position:absolute;top:50%;right:15px;transform:translateY(-50%);width:20px;height:20px;pointer-events:none;color:#666}.color-picker-wrapper input[type=color]{width:90px;height:40px;padding:5px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;background-color:transparent}.color-picker-wrapper input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-wrapper input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.generate-color-btn{padding:8px 16px;background-color:#7b9e89;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.generate-color-btn:hover{background-color:#6a8c78}.color-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:0 var(--spacing-md) var(--spacing-md)}.color-preset{width:100%;aspect-ratio:1/1;border-radius:8px;cursor:pointer;transition:transform .2s}.color-preset:hover{transform:scale(1.05)}.color-preset.selected{box-shadow:0 0 0 3px #7b9e89}.usage-counter{font-size:14px;margin:5px 0;color:var(--text-color-light, #666);text-align:center}.usage-counter span{font-weight:500;color:var(--primary-color, #7B9E89)}
