:root{color:#171717;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f7f4ef;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:#f7f4ef;min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}img,video{display:block}.app-shell{min-height:100dvh;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.app-frame{background:#f7f4ef;max-width:860px;min-height:100dvh;margin:0 auto}.page{min-height:100dvh;padding:24px 24px 112px}.capture-page{padding-top:14px}.page-centered{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.page-header{gap:8px;margin-bottom:24px;display:grid}h1,h2,p{margin:0}h1{letter-spacing:0;font-size:34px;line-height:1.05}h2{font-size:22px;line-height:1.2}p{color:#68635c;line-height:1.5}.lead{max-width:320px;margin:14px auto 30px}.brand-mark{color:#f7f4ef;background:#111;border-radius:22px;place-items:center;width:86px;height:86px;margin-bottom:22px;font-size:54px;font-weight:800;display:grid}.stack,.panel{gap:12px;width:100%;display:grid}.panel{z-index:1;grid-template-columns:1fr 1fr;margin-bottom:20px;position:relative}.button{cursor:pointer;border:0;border-radius:8px;justify-content:center;align-items:center;min-height:52px;padding:0 18px;font-weight:700;text-decoration:none;display:inline-flex}.button:disabled{cursor:not-allowed;opacity:.45}.button.primary{color:#fff;background:#111}.button.secondary{color:#171717;background:#e8e2d8}.button.danger{color:#a83124;background:#ffe1dc}.button.full-width{width:100%}.action-spacer{margin-bottom:18px}.text-link{color:#171717;font-weight:700;text-decoration:none}.top-actions{align-items:center;min-height:42px;margin-bottom:10px;display:flex}.icon-button{color:#171717;background:#e8e2d8;border-radius:50%;place-items:center;width:42px;height:42px;font-size:24px;font-weight:800;text-decoration:none;display:grid}.file-button{position:relative;overflow:hidden}.file-button input{opacity:0;position:absolute;inset:0}.camera-panel{z-index:2;gap:12px;margin-bottom:20px;display:none;position:relative}.camera-panel.visible{display:grid}.crop-toggle{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.crop-toggle button{color:#171717;background:#e8e2d8;border:0;border-radius:8px;min-height:42px;font-weight:700}.crop-toggle button.active{color:#fff;background:#111}.camera-viewport{aspect-ratio:4/5;background:#111;border-radius:8px;width:100%;max-height:58vh;position:relative;overflow:hidden}.camera-video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1) scale(var(--camera-scale,1.18));transform-origin:50%}.camera-preview-canvas{z-index:1;object-fit:cover;opacity:0;pointer-events:none;width:100%;height:100%;transition:opacity .14s;position:absolute;inset:0}.camera-preview-canvas.visible{opacity:1}.white-balance-overlay{z-index:2;pointer-events:none;mix-blend-mode:overlay;position:absolute;inset:0}.camera-flash{z-index:3;opacity:0;pointer-events:none;background:#fff;position:absolute;inset:0}.camera-flash.active{animation:.18s ease-out camera-flash}.countdown-overlay{z-index:4;color:#fff;text-shadow:0 8px 24px #0000005c;pointer-events:none;background:#0000002e;place-items:center;font-size:clamp(88px,28vw,160px);font-weight:900;line-height:1;display:grid;position:absolute;inset:0}@keyframes camera-flash{0%{opacity:0}18%{opacity:.92}to{opacity:0}}.operator-panel{z-index:5;justify-items:end;gap:8px;display:grid;position:absolute;bottom:10px;right:10px}.operator-panel.open{inset:max(12px, env(safe-area-inset-top)) 12px calc(94px + env(safe-area-inset-bottom));z-index:30;align-content:start;justify-items:end;position:fixed}.operator-toggle{color:#fff;background:#111111c7;border:0;border-radius:8px;min-height:32px;padding:0 10px;font-size:12px;font-weight:800}.operator-panel.open .operator-toggle{display:none;position:absolute;top:0;right:0}.operator-controls{color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#111111a3;border-radius:8px;gap:7px;width:min(330px,78vw);max-height:min(520px,78vh);padding:10px;display:grid;overflow:auto}.operator-controls.curve-expanded{width:min(330px,78vw);max-height:min(520px,78vh);overflow:auto}.operator-panel.open .operator-controls,.operator-panel.open .operator-controls.curve-expanded{max-height:min(560px,100dvh - 126px)}.operator-controls strong{color:#f0ddaf;margin-top:2px;font-size:11px}.settings-section-toggle{color:#f0ddaf;background:#ffffff1f;border:0;border-radius:8px;justify-content:space-between;align-items:center;min-height:34px;padding:0 10px;font-size:12px;font-weight:900;display:flex}.settings-section-toggle span:last-child{color:#ffffffad;font-size:11px}.settings-actions,.hsl-tabs{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.settings-actions button,.hsl-tabs button,.preset-select{color:#fff;background:#ffffff24;border:0;border-radius:8px;min-height:32px;font-size:12px;font-weight:800}.hsl-tabs{grid-template-columns:repeat(3,1fr)}.hsl-tabs button.active{color:#171717;background:#fff}.preset-select{width:100%;padding:0 10px}.adjustment-row{grid-template-columns:48px 1fr 32px;align-items:center;gap:8px;font-size:12px;font-weight:700;display:grid}.adjustment-row output{color:#ffffffc2;font-variant-numeric:tabular-nums;text-align:right}.slider-wrap{align-items:center;display:grid;position:relative}.slider-wrap:after{content:"";pointer-events:none;background:#ffffff6b;border-radius:999px;width:2px;height:14px;position:absolute;left:50%;transform:translate(-50%)}.adjustment-row input{--slider-track:linear-gradient(90deg, #555, #9a9a9a);appearance:none;background:0 0;width:100%;min-height:26px}.adjustment-row input::-webkit-slider-runnable-track{background:var(--slider-track);border-radius:999px;height:4px}.adjustment-row input::-webkit-slider-thumb{appearance:none;background:#2d2d2d;border:3px solid #d8d8d8;border-radius:50%;width:18px;height:18px;margin-top:-7px}.tone-curve{aspect-ratio:1;background:#222;border-radius:6px;justify-self:center;width:100%;max-width:min(300px,100%);overflow:hidden}.operator-panel.open .tone-curve{height:auto}.tone-curve svg{touch-action:none;width:100%;height:100%;display:block}.tone-curve line{stroke:#00000075;stroke-width:.4px}.tone-curve .curve-baseline{fill:none;stroke:#ffffff57;stroke-width:1.2px}.tone-curve .curve-line{fill:none;stroke:#fff;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2px}.tone-curve circle{fill:#2c2c2c;stroke:#fff;stroke-width:1.8px;cursor:grab}.notice{color:#5c4b12;background:#fff8df;border-radius:8px;margin:14px 0;padding:12px 14px;font-weight:600}.thumb-grid,.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.thumb-card,.select-card,.gallery-card{background:#fff;border:1px solid #ded7cc;border-radius:8px;overflow:hidden}.thumb-card img,.select-card img,.gallery-card img{aspect-ratio:5/4;object-fit:cover;background:#fff;width:100%}.thumb-card{gap:8px;padding-bottom:10px;display:grid}.thumb-card span{color:#68635c;padding:0 10px;font-size:13px}.thumb-card button{color:#171717;background:#f1ece4;border:0;border-radius:8px;justify-self:start;margin-left:10px;padding:8px 10px}.selected-strip{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px;display:grid}.selected-slot{aspect-ratio:5/4;color:#8a8175;background:#f0e9dd;border:1px dashed #bcb3a7;border-radius:8px;place-items:center;font-weight:800;display:grid;overflow:hidden}.selected-slot img{object-fit:cover;width:100%;height:100%}.select-card{padding:0;position:relative}.select-card.selected{outline:4px solid #111}.select-card span{color:#fff;background:#111;border-radius:50%;place-items:center;width:32px;height:32px;font-weight:800;display:grid;position:absolute;top:8px;right:8px}.template-list{gap:12px;display:grid}.template-card{text-align:left;background:#fff;border:1px solid #ded7cc;border-radius:8px;grid-template-columns:58px 1fr;grid-template-areas:"swatch name""swatch desc";gap:4px 14px;width:100%;padding:14px;display:grid}.template-card.selected{outline:3px solid #111}.template-card span{border-radius:8px;grid-area:swatch;width:58px;height:58px}.template-card strong{grid-area:name;align-self:end}.template-card small{color:#68635c;grid-area:desc}.result-preview{place-items:center;display:grid}.result-preview img{border-radius:8px;max-width:min(100%,520px);max-height:68vh;box-shadow:0 16px 50px #2820182e}.qr-panel{background:#fff;border:1px solid #ded7cc;border-radius:8px;grid-template-columns:104px 1fr;align-items:center;gap:14px;width:min(100%,520px);margin:0 auto;padding:12px;display:grid}.video-panel{gap:12px;width:min(100%,520px);margin:0 auto;display:grid}.video-panel video{background:#111;border-radius:8px;width:100%;max-height:56vh;box-shadow:0 16px 50px #2820182e}.qr-panel img{width:104px;height:104px;image-rendering:pixelated;border-radius:8px}.qr-panel div{gap:6px;min-width:0;display:grid}.qr-panel strong{font-size:16px}.qr-panel span,.qr-panel a{color:#68635c;font-size:13px}.loading-box,.empty-state{text-align:center;background:#efe8dc;border-radius:8px;place-items:center;gap:18px;min-height:280px;display:grid}.gallery-card{color:inherit;text-decoration:none}.gallery-card span{color:#68635c;padding:10px;font-size:13px;display:block}.bottom-bar{z-index:5;width:min(860px,100%);padding:14px 24px calc(14px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f7f4eff0;border-top:1px solid #ded7cc;grid-template-columns:auto 1fr;align-items:center;gap:12px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-bar.multi{grid-template-columns:repeat(3,1fr)}.bottom-bar.quad{grid-template-columns:repeat(4,1fr)}@media (width>=720px){.page{padding:36px 36px 120px}.thumb-grid,.gallery-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (orientation:landscape) and (height<=540px){.page{padding-bottom:92px}.result-preview img{max-height:54vh}}
