:root{--bg-pink:#ffe4ec;--booth-pink:#ff9aae;--pop-red:#ff4757;--ink:#2f3542;--paper:#fffaf0;--neon-blue:#70a1ff;--tape-color:#ffffffb3;--doodle-yellow:gold;--doodle-teal:#7bed9f}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}[hidden]{display:none!important}input,textarea,select{-webkit-user-select:text;user-select:text}html,body{width:100%;margin:0;padding:0;overflow:hidden}body{background-color:#87ceeb;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding-bottom:10vh;font-family:Gaegu,cursive;display:flex}body:has(.camera-page-shell){justify-content:flex-start;height:100dvh;padding-bottom:0}body:has(.frame-page-container){justify-content:flex-start;height:100dvh;padding-bottom:0;overflow:hidden}body:has(.frame-detail-shell){justify-content:flex-start;height:100dvh;padding-bottom:0}body:has(.camera-result-shell){justify-content:flex-start;height:100dvh;padding-bottom:0}body:has(.admin-page-shell){justify-content:flex-start;padding-bottom:0;overflow-y:auto}html:has(.admin-page-shell){overflow-y:auto}body:has(.admin-login-shell){padding-bottom:0}body:after{content:"";pointer-events:none;opacity:.04;z-index:100;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}::view-transition-group(root){animation-duration:.22s;animation-timing-function:cubic-bezier(.22,1,.36,1)}::view-transition-old(root){overflow:clip}::view-transition-new(root){overflow:clip}@media (prefers-reduced-motion:reduce){::view-transition-group(*){animation:none!important}::view-transition-old(*){animation:none!important}::view-transition-new(*){animation:none!important}}.scenic-background{z-index:0;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.sky-layer{z-index:1;background-color:#87ceeb;background-image:repeating-linear-gradient(45deg,#0000 0 10px,#ffffff26 10px 15px);height:60%;position:absolute;top:-10px;left:-10px;right:-10px}.road-layer{border-top:4px solid var(--ink);z-index:2;background-color:khaki;background-image:repeating-linear-gradient(-45deg,#0000 0 3px,#00000014 3px 4px),repeating-linear-gradient(45deg,#0000 0 5px,#6450321a 5px 6px),repeating-linear-gradient(90deg,#0000 0 6px,#0000000d 6px 7px);height:45%;animation:.25s linear infinite squiggly-anim-road;position:absolute;bottom:-10px;left:-10px;right:-10px}@keyframes squiggly-anim-road{0%{filter:url(#squiggly-0)}20%{filter:url(#squiggly-1)}40%{filter:url(#squiggly-2)}60%{filter:url(#squiggly-3)}80%{filter:url(#squiggly-4)}to{filter:url(#squiggly-0)}}.sketchy{filter:url(#squiggly-0);animation:.3s linear infinite squiggly-anim;transform:translateZ(0)}@keyframes squiggly-anim{0%{filter:url(#squiggly-0)}25%{filter:url(#squiggly-1)}50%{filter:url(#squiggly-2)}75%{filter:url(#squiggly-3)}to{filter:url(#squiggly-4)}}@keyframes gentle-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.booth-wrapper{z-index:10;flex-direction:column;flex-shrink:0;align-items:center;width:92%;max-width:360px;display:flex;position:relative}.doodle{z-index:50;opacity:.9;pointer-events:none;position:absolute}.doodle-star{border-left:10px solid #0000;border-right:10px solid #0000;border-bottom:20px solid var(--doodle-color,var(--doodle-yellow));width:0;height:0;position:relative}.doodle-star:after{content:"";border-left:10px solid #0000;border-right:10px solid #0000;border-top:20px solid var(--doodle-color,var(--doodle-yellow));width:0;height:0;position:absolute;top:6px;left:-10px}.doodle-circle{border:3px solid var(--doodle-color,var(--pop-red));border-radius:50% 60% 50% 40%;width:20px;height:20px}.doodle-heart{background-color:var(--doodle-color,var(--pop-red));width:20px;height:20px;display:inline-block;position:relative;transform:rotate(-45deg)}.doodle-heart:before,.doodle-heart:after{content:"";background-color:var(--doodle-color,var(--pop-red));border-radius:50%;width:20px;height:20px;position:absolute}.doodle-heart:before{top:-10px;left:0}.doodle-heart:after{top:0;left:10px}.doodle-heart-flipped{background-color:var(--doodle-color,var(--pop-red));width:20px;height:20px;display:inline-block;position:relative;transform:rotate(45deg)}.doodle-heart-flipped:before,.doodle-heart-flipped:after{content:"";background-color:var(--doodle-color,var(--pop-red));border-radius:50%;width:20px;height:20px;position:absolute}.doodle-heart-flipped:before{top:-10px;right:0}.doodle-heart-flipped:after{top:0;right:10px}.doodle-squiggle{border-bottom:3px dashed var(--doodle-color,var(--neon-blue));border-radius:50%;width:40px;height:10px}.doodle-cloud{opacity:.8;background:#fff;border-radius:20px;width:60px;height:20px;position:relative}.doodle-cloud:before,.doodle-cloud:after{content:"";background:#fff;border-radius:50%;position:absolute}.doodle-cloud:before{width:25px;height:25px;top:-10px;left:10px}.doodle-cloud:after{width:35px;height:35px;top:-15px;right:10px}@keyframes float-cloud{0%{transform:translateX(-100%) scale(var(--cloud-scale,1))}to{transform:translateX(100vw) scale(var(--cloud-scale,1))}}.sign-structure{z-index:20;flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.sign-box{background:var(--pop-red);border:4px solid var(--ink);box-shadow:4px 4px 0px var(--ink);text-align:center;background-image:linear-gradient(45deg,#0000 45%,#0000001a 45% 55%,#0000 55%);background-size:8px 8px;border-radius:60% 40% 50% 50%/50% 60% 40% 50%;margin-bottom:-12px;padding:12px 30px;transform:rotate(-4deg)}.title-text{color:#fff;text-shadow:3px 3px 0px var(--ink);letter-spacing:2px;margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:2.6rem;line-height:.9}.cabin{background-color:var(--booth-pink);border:3px solid var(--ink);z-index:10;background-image:repeating-linear-gradient(90deg,#0000,#0000 40px,#0000000d 40px 43px);border-radius:8px 8px 4px 4px;width:100%;height:380px;display:flex;position:relative;box-shadow:8px 8px #00000026}.panel-left{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:25px;padding:20px 10px;display:flex}.start-poster{background:var(--paper);border:2px solid var(--ink);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;width:100px;height:130px;transition:transform .2s;display:flex;position:relative;transform:rotate(-2deg);box-shadow:2px 2px 5px #0000001a}.start-poster:active{transform:rotate(-2deg)scale(.95)}.start-poster h2{color:var(--pop-red);margin:0;font-size:1.8rem;font-weight:700}.start-poster span{color:#888;font-size:.85rem}.tape{background-color:var(--tape-color);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-left:1px dashed #0003;border-right:1px dashed #0003;width:35px;height:14px;position:absolute;top:-10px;transform:rotate(2deg);box-shadow:0 1px 2px #0000001a}.tag-btn{background:var(--neon-blue);border:2px solid var(--ink);color:#fff;cursor:pointer;box-shadow:2px 2px 0 var(--ink);border-radius:20px 5px;padding:8px 15px;font-size:1rem;font-weight:700;transition:all .2s;transform:rotate(3deg)}.tag-btn:active{box-shadow:0 0 0 var(--ink);transform:rotate(3deg)translate(2px,2px)}.panel-right{border-left:3px solid var(--ink);background:#698289;border-radius:0 6px 0 0;flex:1.1;justify-content:center;display:flex;position:relative;overflow:hidden}.curtain-rod{width:70%;height:60%;position:relative}.curtain{border:3px solid var(--ink);transform-origin:top;background:#2ec4b6;border-top:none;border-radius:0 0 15px 15px;width:100%;height:100%;animation:4s ease-in-out infinite alternate sway}.curtain:before{content:"";background:repeating-linear-gradient(90deg,#0000,#0000 15px,#00000014 20px,#0000 25px);width:100%;height:100%;position:absolute}@keyframes sway{0%{transform:rotate(.5deg)}to{transform:rotate(-.5deg)}}.stool-container{z-index:5;flex-direction:column;align-items:center;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.stool-seat{background:var(--pop-red);border:3px solid var(--ink);z-index:2;border-radius:50%;width:55px;height:16px}.stool-legs{gap:12px;margin-top:-6px;display:flex}.leg{border:2px solid var(--ink);transform-origin:top;background:#d8d8d8;border-radius:4px;width:6px;height:35px}.leg.left{transform:rotate(8deg)}.leg.right{transform:rotate(-8deg)}.floor{background:var(--ink);opacity:.8;border-radius:50%;width:120%;height:4px;margin-top:-2px}.svg-filters{pointer-events:none;width:0;height:0;position:absolute}.frame-page-container{z-index:10;flex-direction:column;align-items:center;width:90%;max-width:400px;height:100%;padding-top:20px;padding-bottom:40px;display:flex;overflow:hidden}.header-sign{background:var(--pop-red);border:3px solid var(--ink);box-shadow:4px 4px 0px var(--ink);background-image:linear-gradient(45deg,#0000 45%,#0000001a 45% 55%,#0000 55%);background-size:8px 8px;border-radius:50% 50% 40% 60%/60% 40%;margin-bottom:30px;padding:10px 30px;transform:rotate(-2deg)}.header-title{color:#fff;text-shadow:2px 2px 0 var(--ink);margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:2rem}.frame-list{-webkit-overflow-scrolling:touch;flex:1;grid-template-columns:repeat(2,1fr);align-items:start;gap:30px;width:100%;min-height:0;padding:15px;display:grid;overflow-y:auto}.frame-card{background:var(--paper);border:1px solid var(--ink);aspect-ratio:3/4;cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:100%;transition:transform .2s,box-shadow .2s;display:flex;position:relative;box-shadow:4px 4px #0000001a}.frame-card:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:8px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.frame-card:active{transform:scale(.95)}.preview-area{border:2px solid var(--ink);color:#888;text-align:center;background:#eee;flex-direction:column;justify-content:center;align-items:center;width:76%;height:76%;font-size:.8rem;display:flex;position:relative;overflow:hidden}.preview-area img{object-fit:contain;width:100%;height:100%}.preview-slide{opacity:0;pointer-events:none;position:absolute;inset:0}.preview-slide.is-active{opacity:1}.preview-photo,.preview-frame{object-fit:contain;position:absolute;inset:0}.preview-frame-only{object-fit:contain}.frame-card-nav{border:2px solid var(--ink);width:30px;height:30px;color:var(--ink);font:inherit;cursor:pointer;z-index:12;background:#fffaf0eb;border-radius:999px;font-weight:700;line-height:1;position:absolute;top:50%;transform:translateY(-50%)}.frame-card-nav-prev{left:8px}.frame-card-nav-next{right:8px}.frame-card-counter{border:2px solid var(--ink);color:var(--ink);z-index:12;background:#fffaf0eb;border-radius:999px;padding:2px 7px;font-size:.75rem;font-weight:700;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.frame-classic .preview-area{border:4px solid var(--ink);background:#fff}.frame-hearts{background:#ffc2d1}.frame-hearts .preview-area{border:2px dashed var(--pop-red);background:var(--bg-pink)}.frame-film{background:#2d2d2d}.frame-film .preview-area{background:#ddd;border:none;width:85%}.frame-polka{background-color:var(--neon-blue);background-image:radial-gradient(#fff 15%,#0000 15%);background-size:10px 10px}.frame-polka .preview-area{border:2px solid var(--ink);background:#fff}.frame-sketch{background:#fff;border-radius:0}.frame-sketch .preview-area{border:3px dashed var(--ink);border-radius:0}.frame-retro{background:#fad02e}.frame-retro .preview-area{color:#fff;background:#222;border-radius:50px}.frame-card.selected{border-color:var(--pop-red);z-index:10;border-width:3px;transform:rotate(-3deg)scale(1.05);box-shadow:6px 6px #0003}.frame-card.selected:after{border-color:var(--pop-red)}.frame-card.selected:before{content:"SELECTED";background:var(--pop-red);color:#fff;border:2px solid var(--ink);z-index:20;padding:5px 10px;font-size:1.2rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-10deg);box-shadow:2px 2px #0003}.selection-tape{background:var(--tape-color);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:5;border-left:1px dashed #ccc;border-right:1px dashed #ccc;width:40px;height:20px;display:none;position:absolute;top:-12px;left:35%;transform:rotate(2deg)}.frame-card.selected .selection-tape{display:block}.action-bar{gap:20px;margin-top:30px;display:flex}.btn{border:3px solid var(--ink);cursor:pointer;box-shadow:3px 3px 0 var(--ink);border-radius:12px;padding:10px 30px;font-family:Gaegu,cursive;font-size:1.5rem;font-weight:700;text-decoration:none;transition:transform .1s;display:inline-block}.btn:active{box-shadow:none;transform:translate(3px,3px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-back{background:var(--paper);color:var(--ink)}.btn-next{background:var(--neon-blue);color:#fff;transform:rotate(-2deg)}.btn-next:disabled{transform:rotate(-2deg)}.film-holes{background-image:radial-gradient(#fff 20%,#0000 20%);background-size:10px 15px;width:10px;position:absolute;top:0;bottom:0;left:5px}.back-btn{background:var(--paper);border:3px solid var(--ink);cursor:pointer;box-shadow:3px 3px 0 var(--ink);color:var(--ink);z-index:100;border-radius:12px;padding:8px 16px;font-family:Gaegu,cursive;font-size:1.2rem;font-weight:700;text-decoration:none;transition:transform .1s;position:fixed;top:20px;left:20px}.back-btn:active{box-shadow:none;transform:translate(3px,3px)}.frame-loader{text-align:center;color:var(--ink);opacity:.7;grid-column:1/-1;padding:20px;font-size:1.2rem}.frame-detail-shell{z-index:10;grid-template-rows:auto minmax(0,1fr) auto;gap:12px;width:min(760px,100% - 24px);height:100dvh;margin:0 auto;padding:18px 0;display:grid;position:relative;overflow:hidden}.frame-detail-header{border:3px solid var(--ink);text-align:center;background:#fffaf0f0;border-radius:26px;margin:0 auto;padding:18px 20px;box-shadow:6px 6px #0000001f}.frame-detail-title{margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:clamp(2.1rem,7vw,3.2rem)}.frame-detail-card{border:3px solid var(--ink);background:#fffaf0f0;border-radius:28px;flex-direction:column;min-height:0;padding:20px;display:flex;position:relative;box-shadow:6px 6px #0000001f}.frame-detail-card:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:28px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.frame-detail-stage{border:3px solid var(--ink);background:#ffffffe0;border-radius:24px;flex:1 1 0;min-height:0;position:relative;overflow:hidden}.frame-detail-image{object-fit:contain;opacity:0;width:100%;height:100%;position:absolute;inset:0}.frame-detail-image.is-active{opacity:1}.frame-detail-nav{border:2px solid var(--ink);width:38px;height:38px;color:var(--ink);font:inherit;cursor:pointer;z-index:2;background:#fffaf0eb;border-radius:999px;font-weight:700;position:absolute;top:50%;transform:translateY(-50%)}.frame-detail-nav-prev{left:12px}.frame-detail-nav-next{right:12px}.frame-detail-counter{border:2px solid var(--ink);z-index:2;background:#fffaf0eb;border-radius:999px;padding:4px 9px;font-size:.82rem;font-weight:700;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.frame-detail-actions{z-index:12;flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.frame-detail-capture-btn{width:100%;font:inherit;color:#fff;background:var(--pop-red);border:2px solid var(--ink);text-align:center;border-radius:20px;padding:18px 20px;font-size:1.15rem;font-weight:700;text-decoration:none;display:block;box-shadow:4px 4px #0000001f}.camera-page-shell{z-index:10;flex:1 1 0;grid-template-rows:auto minmax(0,1fr) auto;gap:12px;width:min(920px,100% - 24px);min-height:0;padding:10px 2px;display:grid;position:relative;overflow:hidden}.camera-header{border:3px solid var(--ink);text-align:center;background:#fffaf0f0;border-radius:24px;margin:0 auto;padding:18px 20px;box-shadow:6px 6px #0000001f}.camera-title{color:var(--ink);margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:clamp(2.1rem,7vw,3rem)}.camera-subtitle{color:#2f3542bd;margin:6px 0 0;font-size:1rem;font-weight:700}.camera-stage-card{border:3px solid var(--ink);background:#fffaf0f0;border-radius:28px;width:100%;min-width:0;min-height:0;padding:14px;position:relative;box-shadow:6px 6px #0000001f}.camera-stage-card:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:28px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.camera-stage{border:3px solid var(--ink);background:#ffffffe0;border-radius:24px;justify-content:center;align-items:center;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}.camera-preview-window{background:#ffffffb8;border-radius:20px;flex:none;width:100%;max-width:100%;height:100%;max-height:100%;position:relative;overflow:hidden}.camera-upload-board{background:#ffffffe6;border:2px solid #2f35422e;flex:none;position:relative;box-shadow:0 20px 44px #2f354224}.camera-upload-photos,.camera-upload-slot-layer{position:absolute;inset:0}.camera-upload-photos{z-index:1}.camera-upload-frame{object-fit:cover;z-index:3;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.camera-upload-slot-layer{z-index:4}.camera-upload-slot-photo,.camera-upload-slot-control{position:absolute}.camera-upload-slot-photo{background:linear-gradient(135deg,#70a1ff33,#ffffff80),repeating-linear-gradient(-45deg,#2f35420d 0 10px,#ffffff0a 10px 20px);overflow:hidden;box-shadow:inset 0 0 0 2px #2f35421f}.camera-upload-slot-photo.is-filled{background:#fffffff5}.camera-upload-slot-photo-image{object-fit:cover;width:100%;height:100%;display:block}.camera-upload-slot-control{background:linear-gradient(#2f354214,#2f354229);justify-content:center;align-items:flex-end;padding:10px;display:flex}.camera-upload-slot-control.is-filled{background:linear-gradient(#2f354205,#2f354238)}.camera-slot-upload-btn{width:auto;max-width:min(100%,132px);min-height:34px;padding:7px 12px;font-size:.82rem;line-height:1.1}.camera-upload-slot-control.is-filled .camera-slot-upload-btn{background:#ff4757b8}.camera-upload-slot-control.is-filled .camera-slot-upload-btn[data-whimsy=cross]:before,.camera-upload-slot-control.is-filled .camera-slot-upload-btn[data-whimsy=cross]:after{background:#fffaf0e6}.camera-stage canvas{width:100%;height:100%;display:block}.camera-preview-window canvas{transform-origin:50%;transform:scaleX(-1)}.camera-stage-placeholder{text-align:center;color:#2f3542bd;z-index:5;justify-content:center;align-items:center;padding:20px;display:flex;position:absolute;inset:0}.camera-stage-placeholder.has-error{color:var(--pop-red)}.camera-guide{pointer-events:none;z-index:3;border:3px solid #fffffff2;border-radius:20px;position:absolute;inset:0;box-shadow:0 0 0 3px #2f354257}.camera-guide:before,.camera-guide:after{content:"";border:2px dashed #ffffffd1;border-radius:14px;position:absolute;inset:12px}.camera-shot-progress{background:var(--pop-red);border:3px solid var(--ink);color:#fff;text-shadow:2px 2px 0 var(--ink);box-shadow:4px 4px 0 var(--ink);z-index:4;filter:url(#squiggly-0);border-radius:50% 50% 40% 60%/60% 40%;padding:12px 28px;font-family:Rubik Doodle Shadow,cursive;font-size:1.6rem;animation:.3s linear infinite squiggly-anim;position:absolute;top:-8px;left:50%;transform:translate(-50%)rotate(-2deg)}.camera-countdown{border:3px solid var(--ink);z-index:5;background:#fffaf0f5;border-radius:999px;place-items:center;width:88px;height:88px;font-size:2.8rem;font-weight:700;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.camera-flash{opacity:0;z-index:999;pointer-events:none;background:#fff;transition:opacity 60ms linear;position:fixed;inset:0}.camera-flash.is-visible{opacity:.98}.camera-processing-title{color:var(--ink);border:3px solid var(--ink);background:#fffaf0f0;border-radius:16px;padding:10px 16px;font-size:1.15rem;font-weight:700;box-shadow:4px 4px #0000001f}.camera-processing-countdown{border:3px solid var(--ink);background:#ffffffeb;border-radius:999px;place-items:center;width:74px;height:74px;font-size:2rem;font-weight:700;display:grid;box-shadow:4px 4px #0000001f}.camera-review-image{object-fit:contain;max-width:100%;max-height:100%}.camera-filter-dock{border:3px solid var(--ink);background:#fffaf0f7;border-radius:20px;gap:10px;width:100%;min-width:0;margin-top:0;padding:10px;display:grid;position:relative;box-shadow:6px 6px #0000001f}.camera-filter-dock:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:20px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.camera-live-controls{gap:10px;display:grid}.camera-upload-controls{justify-content:space-between;align-items:center;gap:14px;display:flex}.camera-upload-copy{gap:4px;display:grid}.camera-upload-title{color:var(--ink);font-size:1rem;font-weight:800}.camera-upload-text{color:#2f3542bd;font-size:.95rem}.camera-control-row{grid-template-columns:auto minmax(0,1fr);align-items:end;gap:10px;display:grid}.camera-settings-group{grid-template-columns:1fr 1fr;align-items:end;gap:10px;display:grid}.camera-control{color:var(--ink);gap:4px;font-weight:700;display:grid}.camera-timer-dropdown{position:relative}.camera-timer-trigger{border:2px solid var(--ink);width:100%;font:inherit;color:var(--ink);cursor:pointer;filter:url(#squiggly-0);background:#fffffff0;border-radius:14px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-weight:700;transition:transform .15s,box-shadow .15s;animation:.4s linear infinite squiggly-anim,2.5s ease-in-out infinite gentle-bob;display:flex}.camera-timer-trigger:hover{transform:translateY(-1px);box-shadow:2px 2px #0000001a}.camera-timer-trigger:active{transform:translate(1px,1px);box-shadow:1px 1px #0000001a}.camera-timer-trigger svg{transition:transform .2s}.camera-timer-dropdown.is-open .camera-timer-trigger svg{transform:rotate(180deg)}.camera-timer-options{z-index:100;border:3px solid var(--ink);filter:url(#squiggly-0);overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--ink) #ffffff80;background:#fffaf0fa;border-radius:16px;gap:4px;min-width:84px;padding:8px;animation:.35s linear infinite squiggly-anim;display:grid;position:absolute;top:calc(100% + 6px);left:0;overflow-y:auto;box-shadow:4px 4px #0000001f}.camera-timer-dropdown.is-open-upward .camera-timer-options{top:auto;bottom:calc(100% + 6px)}.camera-timer-options:before{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-bottom:8px solid var(--ink);width:0;height:0;position:absolute;top:-8px;left:20px}.camera-timer-dropdown.is-open-upward .camera-timer-options:before{border-bottom:0;border-top:8px solid var(--ink);top:auto;bottom:-8px}.camera-timer-option{width:100%;font:inherit;color:var(--ink);text-align:left;cursor:pointer;background:0 0;border:2px solid #0000;border-radius:12px;padding:8px 12px;font-weight:700;transition:all .15s;display:block}.camera-timer-option:hover{border-color:var(--pop-red);background:#ff47571a}.camera-timer-option.is-selected{background:var(--pop-red);color:#fff;border-color:var(--ink)}.camera-timer-custom{background:#ffffff9e;border:2px dashed #2f354247;border-radius:12px;gap:8px;margin-top:4px;padding:10px;display:grid}.camera-timer-custom-label{color:#2f3542cc;font-size:.82rem;font-weight:700}.camera-timer-custom-row{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.camera-timer-custom-row input{border:2px solid var(--ink);width:100%;min-width:0;font:inherit;color:var(--ink);background:#fffffff5;border-radius:10px;padding:8px 10px;font-weight:700}.camera-timer-custom-apply{border:2px solid var(--ink);background:var(--neon-blue);font:inherit;color:#fff;cursor:pointer;border-radius:10px;padding:8px 12px;font-weight:700}.camera-timer-options::-webkit-scrollbar{width:10px}.camera-timer-options::-webkit-scrollbar-thumb{background:#2f3542b3;border:2px solid #fffaf0f2;border-radius:999px}.camera-timer-options::-webkit-scrollbar-track{background:0 0}.camera-toggle{border:2px solid var(--ink);width:100%;min-height:48px;color:var(--ink);cursor:pointer;filter:url(#squiggly-0);background:#fffffff0;border-radius:14px;justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s;animation:.4s linear infinite squiggly-anim,2.5s ease-in-out .3s infinite gentle-bob;display:flex}.camera-toggle:hover{transform:translateY(-2px);box-shadow:2px 2px #0000001a}.camera-toggle:has(input:checked){background:var(--doodle-yellow);color:var(--ink);border-color:var(--ink)}.camera-toggle input{opacity:0;width:0;height:0;position:absolute}.camera-start-btn,.camera-action-btn{border:2px solid var(--ink);min-height:48px;font:inherit;cursor:pointer;border-radius:16px;justify-content:center;align-items:center;padding:12px 16px;font-weight:700;text-decoration:none;display:inline-flex}.camera-start-btn{color:#fff;background:var(--pop-red)}.camera-start-btn:disabled,.camera-control select:disabled,.camera-toggle input:disabled{opacity:.55;cursor:not-allowed}.camera-action-btn{color:var(--ink);background:#ffffffeb}.camera-action-btn-primary{color:#fff;background:var(--pop-red)}.camera-filter-dock .filter-strip.is-compact{scroll-snap-type:x proximity;grid-auto-columns:74px;align-items:start;gap:8px;padding:0 1px 2px}.camera-filter-dock .filter-strip.is-compact .filter-card{box-shadow:none;scroll-snap-align:start;border-radius:14px;gap:0;padding:4px}.camera-filter-dock .filter-strip.is-compact .filter-card.is-selected{box-shadow:0 0 0 3px #ff475724}.camera-filter-dock .filter-strip.is-compact .filter-card-image{aspect-ratio:1/1.18;border-radius:10px}.camera-crop-modal{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:120;background:#2f354273;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.camera-crop-dialog{border:3px solid var(--ink);background:#fffaf0fa;border-radius:28px;gap:16px;width:min(720px,100%);padding:20px;display:grid;box-shadow:10px 10px #00000024}.camera-crop-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.camera-crop-title{color:var(--ink);font-size:1.2rem;font-weight:800}.camera-crop-copy{color:#2f3542bd;margin-top:4px}.camera-crop-close{flex:none}.camera-crop-stage{background:radial-gradient(circle at top,#70a1ff2e,#0000 55%),#ffffffe6;border:2px solid #2f354224;border-radius:24px;place-items:center;min-height:260px;padding:8px;display:grid}.camera-crop-viewport{touch-action:none;cursor:grab;background:#2f354214;border-radius:24px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 2px #2f354224}.camera-crop-viewport.is-dragging{cursor:grabbing}.camera-crop-image{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;max-width:none;position:absolute}.camera-crop-frame{pointer-events:none;border:3px solid #fffffff5;border-radius:24px;position:absolute;inset:0;box-shadow:inset 0 0 0 2px #2f35422e}.camera-crop-frame:before{content:"";border:2px dashed #ffffffd9;border-radius:16px;position:absolute;inset:12px}.camera-crop-zoom{color:var(--ink);gap:8px;font-weight:700;display:grid}.camera-crop-zoom input{width:100%}.camera-crop-actions{justify-content:flex-end;display:flex}.camera-result-shell{z-index:10;grid-template-rows:auto minmax(0,1fr) auto;gap:12px;width:min(760px,100% - 24px);height:100dvh;margin:0 auto;padding:18px 0;display:grid;position:relative;overflow:hidden}.camera-result-header{border:3px solid var(--ink);text-align:center;background:#fffaf0f5;border-radius:24px;margin:0 auto;padding:18px 20px;box-shadow:6px 6px #0000001f}.camera-result-card{border:3px solid var(--ink);background:#fffaf0f5;border-radius:28px;flex-direction:column;min-height:0;padding:20px;display:flex;position:relative;box-shadow:6px 6px #0000001f}.camera-result-card:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:28px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.camera-result-stage{border:3px solid var(--ink);background:#ffffffe0;border-radius:24px;flex:1 1 0;min-height:0;position:relative;overflow:hidden}.camera-result-wait,.camera-result-final,.camera-result-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:18px;display:flex;position:absolute;inset:0}.camera-result-final{justify-content:center}.camera-result-empty{color:#2f3542b8}.camera-result-actions{gap:10px;display:grid}.frame-detail-empty{color:#2f3542b8;text-align:center;background:#ffffff8f;border:2px dashed #2f35424d;border-radius:20px;padding:36px 20px}.frame-list::-webkit-scrollbar{background:0 0;width:0}.frame-list{-ms-overflow-style:none;scrollbar-width:none}.admin-page-shell{z-index:10;width:min(960px,100% - 32px);margin:16px auto;padding:24px 20px 40px;position:relative}.admin-login-shell{z-index:10;width:min(460px,100% - 24px);position:relative}.admin-login-card{border:3px solid var(--ink);background:#fffaf0f0;border-radius:28px;padding:28px 24px;box-shadow:6px 6px #0000001f}.admin-login-title{color:var(--ink);margin:0 0 8px;font-family:Rubik Doodle Shadow,cursive;font-size:clamp(2.1rem,9vw,3rem)}.admin-login-copy{color:#2f3542c7;margin:0 0 18px}.admin-login-form{gap:14px;display:grid}.admin-header{background:var(--paper);border:3px solid var(--ink);border-radius:24px;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;padding:18px 20px;display:flex;box-shadow:6px 6px #0000001f}.admin-kicker{letter-spacing:.08em;color:var(--pop-red);margin:0 0 6px;font-size:.9rem}.admin-title{color:var(--ink);margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:clamp(2rem,6vw,3rem)}.admin-header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-header-actions form{margin:0}.admin-back-link{color:var(--ink);border:2px solid var(--ink);background:#fffc;border-radius:999px;justify-content:center;align-items:center;padding:10px 14px;font-weight:700;text-decoration:none;display:inline-flex}.admin-logout-btn{font:inherit;color:var(--ink);border:2px solid var(--ink);cursor:pointer;background:#ffffffd9;border-radius:999px;justify-content:center;align-items:center;padding:10px 14px;font-weight:700;display:inline-flex}.admin-notice{border:3px solid var(--ink);background:var(--paper);border-radius:18px;margin-bottom:16px;padding:14px 16px;transition:opacity .2s,transform .2s;box-shadow:4px 4px #0000001a}.admin-notice.is-hiding{opacity:0;transform:translateY(-6px)}.admin-notice-success{background:#e8fff0}.admin-notice-error{background:#ffe4e6}.admin-card{border:3px solid var(--ink);background:#fffaf0eb;border-radius:28px;margin-bottom:20px;padding:20px;position:relative;box-shadow:6px 6px #0000001f}.admin-card:after{content:"";border:3px solid var(--ink);pointer-events:none;z-index:10;filter:url(#squiggly-0);border-radius:28px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.admin-card-header{margin-bottom:18px}.admin-card-header-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.admin-card-title{margin:0 0 4px;font-size:1.8rem}.admin-card-copy{color:#2f3542c7;margin:0}.admin-upload-form,.admin-frame-row{gap:14px;display:grid}.admin-upload-form{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr) minmax(0,1.2fr);align-items:end}.admin-upload-form>.admin-options-row,.admin-upload-form>.admin-submit-btn{grid-column:1/-1}.admin-field{flex-direction:column;gap:6px;min-width:0;font-weight:700;display:flex}.admin-field span{font-size:.95rem}.admin-field input{width:100%;max-width:100%;font:inherit;border:2px solid var(--ink);-webkit-user-select:text;user-select:text;background:#fff;border-radius:14px;padding:12px 14px}.admin-field select{width:100%;max-width:100%;font:inherit;border:2px solid var(--ink);background:#fff;border-radius:14px;padding:12px 14px}.admin-field input[aria-invalid=true]{border-color:#c44b63;box-shadow:0 0 0 3px #c44b6324}.admin-field-error{color:#c44b63;min-height:1.1rem;font-size:.88rem;font-weight:700}.admin-field-error[hidden]{display:none}.admin-field-file input{min-width:0;padding:9px 10px;display:block}.whimsical-file-input{align-items:center;gap:8px;width:100%;display:inline-flex;position:relative}.whimsical-file-input input[type=file]{opacity:0;cursor:pointer;z-index:2;position:absolute;inset:0}.whimsical-file-input .file-btn{width:100%;font:inherit;color:var(--ink);background:var(--paper);border:3px solid var(--ink);cursor:pointer;filter:url(#squiggly-0);border-radius:16px;align-items:center;gap:8px;padding:12px 16px;font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s;animation:.35s linear infinite squiggly-anim;display:inline-flex;box-shadow:3px 3px #0000001f}.whimsical-file-input:hover .file-btn{transform:translateY(-2px);box-shadow:4px 4px #00000026}.whimsical-file-input input[type=file]:active+.file-btn,.whimsical-file-input .file-btn:active{transform:translate(2px,2px);box-shadow:1px 1px #0000001f}.whimsical-file-input .file-icon{width:28px;height:28px;color:var(--ink);flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:inline-flex}.whimsical-file-input .file-icon svg{width:20px;height:20px;display:block}.whimsical-file-input .file-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.whimsical-file-input .file-text.placeholder{color:#2f354299}.whimsical-file-input.has-file .file-btn{border-color:var(--neon-blue);background:linear-gradient(135deg,#e8f4ff 0%,#fff 100%)}.whimsical-file-input.has-file .file-text{color:var(--neon-blue)}.whimsical-file-input .file-btn:before{content:"";background:var(--tape-color);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:.9;border-left:1px dashed #0003;border-right:1px dashed #0003;width:32px;height:14px;position:absolute;top:-8px;left:20px;transform:rotate(-3deg);box-shadow:0 1px 2px #00000014}.whimsical-file-input.is-multiple .file-btn{background:linear-gradient(135deg,#fff8e7 0%,#fff 100%);border-color:#f0c040}.whimsical-file-input.is-multiple.has-file .file-btn{background:linear-gradient(135deg,#fff3d6 0%,#fff 100%);border-color:#e8a838}.whimsical-file-input.is-multiple .file-btn:before{background:#ffc86499;left:auto;right:24px;transform:rotate(4deg)}.whimsy-btn{font:inherit;color:#fff;background:var(--pop-red);border:3px solid var(--ink);cursor:pointer;filter:url(#squiggly-0);border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:14px 24px;font-size:1.1rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s;animation:.35s linear infinite squiggly-anim;display:inline-flex;position:relative;box-shadow:4px 4px #00000026}.whimsy-btn:hover{transform:translateY(-2px);box-shadow:5px 5px #0000002e}.whimsy-btn:active{transform:translate(2px,2px);box-shadow:2px 2px #0000001f}.whimsy-btn[data-whimsy=tape]:before{content:"";background:var(--tape-color);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-left:1px dashed #0003;border-right:1px dashed #0003;width:32px;height:14px;position:absolute;top:-8px;left:50%;transform:translate(-50%)rotate(-2deg);box-shadow:0 1px 2px #00000014}.whimsy-btn[data-whimsy=cross]:before,.whimsy-btn[data-whimsy=cross]:after{content:"";background:var(--doodle-yellow);border:2px solid var(--ink);border-radius:3px;width:24px;height:6px;position:absolute;top:-5px;left:50%;transform:translate(-50%)}.whimsy-btn[data-whimsy=cross]:before{transform:translate(-50%)rotate(45deg)}.whimsy-btn[data-whimsy=cross]:after{transform:translate(-50%)rotate(-45deg)}.whimsy-btn[data-whimsy=star]:before{content:"★";color:var(--doodle-yellow);text-shadow:2px 2px 0 var(--ink);font-size:1.4rem;position:absolute;top:-12px;right:10px;transform:rotate(15deg)}.whimsy-btn[data-whimsy=heart]:before{content:"♥";color:var(--pop-red);text-shadow:1px 1px 0 var(--ink);font-size:1.2rem;position:absolute;top:-10px;left:12px;transform:rotate(-10deg)}.whimsy-btn[data-whimsy=circle]:before{content:"";border:3px solid var(--neon-blue);background:0 0;border-radius:50%;width:18px;height:18px;position:absolute;top:-8px;right:15px;transform:rotate(5deg)}.whimsy-btn-secondary{background:var(--paper);color:var(--ink)}.whimsy-btn-blue{background:var(--neon-blue)}.whimsy-btn-green{background:#2ecc71}.admin-checkbox-field{border:2px solid var(--ink);background:#ffffffe0;border-radius:16px;align-items:center;gap:10px;min-width:0;padding:12px 14px;font-weight:700;display:inline-flex}.admin-checkbox-field input{width:18px;height:18px;margin:0}.admin-upload-layout{grid-column:1/-1}.admin-submit-btn,.admin-save-btn{font:inherit;color:#fff;background:var(--pop-red);border:2px solid var(--ink);cursor:pointer;border-radius:16px;justify-self:start;padding:12px 18px;font-weight:700;box-shadow:3px 3px #00000026}.admin-sort-toggle-btn,.admin-edit-name-btn,.admin-cancel-btn,.admin-delete-btn,.admin-layout-btn{font:inherit;color:var(--ink);border:2px solid var(--ink);cursor:pointer;background:#ffffffe6;border-radius:999px;padding:10px 14px;font-weight:700}.admin-sort-toggle-btn.is-active{background:var(--neon-blue);color:#fff}.admin-sort-help{background:#70a1ff2e;border:2px solid #2f35422e;border-radius:18px;margin-bottom:16px;padding:12px 14px}.admin-frame-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.admin-frame-item{background:#ffffffb8;border:2px solid #2f35422e;border-radius:22px;flex-direction:column;gap:12px;padding:16px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;position:relative}.admin-frame-item:after{content:"";pointer-events:none;z-index:10;filter:url(#squiggly-0);border:2px solid #2f35422e;border-radius:22px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.admin-frame-item.is-editing{border-color:var(--neon-blue);box-shadow:0 0 0 4px #70a1ff26}.admin-frame-card-shell .frame-card{width:100%}.admin-frame-footer{flex-direction:column;gap:10px;display:flex}.admin-frame-title-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-frame-actions{justify-content:flex-end;align-items:center;gap:8px;min-width:100px;display:flex}.admin-frame-order-actions,.admin-example-order-actions{align-items:center;gap:6px;display:flex}.admin-frame-order-actions{display:none}.admin-frame-name{color:var(--ink);font-size:1.15rem;font-weight:700}.admin-name-form{gap:12px;display:grid}.admin-options-row{grid-column:1/-1;gap:12px;display:grid}.admin-filter-dropdown{width:100%;min-width:0;position:relative}.admin-filter-trigger,.admin-filter-option{appearance:none;box-sizing:border-box;-webkit-tap-highlight-color:transparent;background-image:none;margin:0;font-family:inherit;text-decoration:none}.admin-filter-trigger{width:100%;min-height:50px;font:inherit;text-align:left;border:2px solid var(--ink);color:var(--ink);cursor:pointer;filter:url(#squiggly-0);background:linear-gradient(#fffffffa,#fff4f7f0);border-radius:14px;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;font-size:16px;font-weight:700;line-height:1.2;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;animation:.4s linear infinite squiggly-anim,2.5s ease-in-out .1s infinite gentle-bob;display:flex;box-shadow:3px 3px #0000001f}.admin-filter-trigger:hover{transform:translateY(-1px);box-shadow:5px 5px #0000001f}.admin-filter-trigger:active{transform:translate(1px,1px);box-shadow:2px 2px #0000001f}.admin-filter-trigger:focus{border-color:var(--neon-blue);outline:none;box-shadow:0 0 0 4px #70a1ff2e,4px 4px #0000001f}.admin-filter-trigger-value{min-width:0}.admin-filter-chevron{color:var(--ink);pointer-events:none;justify-content:center;align-items:center;transition:color .15s,transform .2s;display:inline-flex}.admin-filter-dropdown.is-open .admin-filter-chevron,.admin-filter-trigger:focus .admin-filter-chevron{color:var(--neon-blue);transform:rotate(180deg)}.admin-filter-options{z-index:120;border:3px solid var(--ink);filter:url(#squiggly-0);overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--ink) #ffffff80;background:#fffaf0fa;border-radius:16px;gap:4px;width:100%;min-width:0;padding:8px;animation:.35s linear infinite squiggly-anim;display:grid;position:absolute;top:calc(100% + 6px);left:0;overflow-y:auto;box-shadow:4px 4px #0000001f}.admin-filter-dropdown.is-open-upward .admin-filter-options{top:auto;bottom:calc(100% + 6px)}.admin-filter-options:before{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-bottom:8px solid var(--ink);width:0;height:0;position:absolute;top:-8px;right:20px}.admin-filter-dropdown.is-open-upward .admin-filter-options:before{border-bottom:0;border-top:8px solid var(--ink);top:auto;bottom:-8px}.admin-filter-option{width:100%;min-height:44px;font:inherit;color:var(--ink);text-align:left;cursor:pointer;background:0 0;border:2px solid #0000;border-radius:12px;padding:10px 12px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:block}.admin-filter-options::-webkit-scrollbar{width:10px}.admin-filter-options::-webkit-scrollbar-thumb{background:#2f3542b3;border:2px solid #fffaf0f2;border-radius:999px}.admin-filter-options::-webkit-scrollbar-track{background:0 0}.admin-filter-option:hover{border-color:var(--pop-red);background:#ff47571a}.admin-filter-option.is-selected{background:var(--pop-red);color:#fff;border-color:var(--ink)}@media (width>=640px){.admin-options-row{grid-template-columns:auto 1fr;align-items:center}}.admin-name-form[hidden]{display:none}.admin-name-actions{flex-wrap:wrap;gap:10px;display:flex}.admin-delete-btn{background:#ffe4e6eb}.admin-layout-editor{background:#ffffffb8;border:2px solid #2f354229;border-radius:20px;gap:12px;padding:14px;display:grid;position:relative}.admin-layout-editor:after{content:"";pointer-events:none;z-index:10;filter:url(#squiggly-0);border:2px solid #2f354229;border-radius:20px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.admin-layout-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-layout-title{color:var(--ink);font-size:1rem;font-weight:700}.admin-layout-copy{color:#2f3542b8;font-size:.9rem}.admin-layout-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-layout-editor.is-empty .admin-layout-list-wrap{display:none}.admin-layout-btn.is-active{background:var(--neon-blue);color:#fff}.admin-layout-stage{background:#ffffff8f;border:2px dashed #2f35423d;border-radius:18px;place-items:center;min-height:220px;padding:12px;display:grid}.admin-layout-canvas{max-width:100%;line-height:0;display:inline-block;position:relative}.admin-layout-image{max-width:100%;max-height:min(68vh,560px);display:block}.admin-layout-overlay{position:absolute;inset:0}.admin-layout-slot{border:2px solid var(--pop-red);cursor:move;background:#ff475729;border-radius:10px;margin:0;padding:0;display:block;position:absolute}.admin-layout-slot.is-selected{border-color:var(--neon-blue);background:#70a1ff2e}.admin-layout-slot-alpha-detected{cursor:pointer;background-color:#fff3;border-style:dashed}.admin-layout-slot-alpha-detected.is-selected{background-color:#70a1ff42}.admin-layout-slot-label{border:2px solid var(--ink);min-width:24px;color:var(--ink);background:#fffaf0f0;border-radius:999px;padding:2px 6px;font-size:.85rem;font-weight:700;position:absolute;top:6px;left:6px}.admin-layout-slot-handle{border:2px solid var(--ink);background:var(--paper);cursor:nwse-resize;border-radius:999px;width:16px;height:16px;position:absolute;bottom:-7px;right:-7px}.admin-layout-empty{color:#2f3542b8;text-align:center}.admin-layout-list-wrap{gap:8px;display:grid}.admin-layout-status{color:#2f3542b8;min-height:1.25rem;font-size:.9rem}.admin-layout-status.is-error{color:var(--pop-red)}.admin-layout-list-title{color:var(--ink);font-weight:700}.admin-layout-list{gap:8px;display:grid}.admin-layout-slot-row{background:#ffffffe6;border:2px solid #2f354224;border-radius:16px;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;display:flex;position:relative}.admin-layout-slot-row:after{content:"";pointer-events:none;z-index:10;filter:url(#squiggly-0);border:2px solid #2f354224;border-radius:16px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.admin-layout-slot-row.is-selected{border-color:var(--neon-blue);box-shadow:0 0 0 3px #70a1ff24}.admin-layout-slot-row-main{text-align:left;min-width:0;color:var(--ink);font:inherit;cursor:pointer;background:0 0;border:0;flex:1;gap:2px;margin:0;padding:0;display:grid}.admin-layout-slot-row-label{font-weight:700}.admin-layout-slot-row-meta{color:#2f3542b8;font-size:.88rem}.admin-layout-slot-row-actions{align-items:center;gap:6px;display:flex}.admin-example-section{gap:10px;display:grid}.admin-example-section-head{flex-wrap:wrap;justify-content:space-between;gap:12px;font-weight:700;display:flex}.admin-example-copy,.admin-example-empty{color:#2f3542b8;font-size:.9rem}.admin-example-list{gap:10px;display:grid}.admin-example-item{background:#ffffffe0;border:2px solid #2f354224;border-radius:18px;align-items:center;gap:12px;padding:10px;display:flex;position:relative}.admin-example-item:after{content:"";pointer-events:none;z-index:10;filter:url(#squiggly-0);border:2px solid #2f354224;border-radius:18px;animation:.3s linear infinite squiggly-anim;position:absolute;inset:0}.admin-example-thumb{object-fit:cover;flex-shrink:0;width:68px;height:90px}.admin-example-item-actions{justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.admin-order-btn{width:34px;height:34px;font:inherit;color:var(--ink);border:2px solid var(--ink);cursor:pointer;background:#ffffffeb;border-radius:999px;justify-content:center;align-items:center;padding:0;font-weight:700;display:inline-flex}.admin-order-btn:disabled{opacity:.35;cursor:not-allowed}.admin-drag-badge{color:var(--pop-red);font-size:.9rem;font-weight:700;display:none}.admin-frame-grid.is-sorting .admin-drag-badge{display:block}.admin-frame-grid.is-sorting .admin-edit-name-btn,.admin-frame-grid.is-sorting .admin-name-form{display:none}.admin-frame-grid.is-sorting .admin-frame-order-actions{display:inline-flex}.admin-empty-state{text-align:center;background:#ffffff8c;border:2px dashed #2f354259;border-radius:20px;padding:24px}.filter-strip{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.filter-strip.is-compact{scrollbar-width:none;grid-template-columns:none;grid-auto-columns:88px;grid-auto-flow:column;gap:10px;padding-bottom:2px;display:grid;overflow:auto hidden}.filter-strip.is-compact::-webkit-scrollbar{display:none}.filter-strip.is-disabled{opacity:.7}.filter-card{text-align:left;border:2px solid var(--ink);color:var(--ink);font:inherit;cursor:pointer;background:#fffaf0f0;border-radius:18px;align-content:start;gap:8px;padding:12px;display:grid}.filter-card-media{display:block;position:relative}.filter-card.is-selected{border-color:var(--pop-red);box-shadow:0 0 0 4px #ff475724}.filter-card-image{aspect-ratio:3/4;object-fit:cover;background:#fff;border:2px solid #2f35421f;border-radius:14px;width:100%}.filter-card-badge{border:2px solid var(--ink);background:var(--doodle-yellow);width:26px;height:26px;color:var(--ink);border-radius:999px;justify-content:center;place-items:center;font-size:.9rem;font-weight:800;line-height:1;display:grid;position:absolute;top:8px;left:8px;box-shadow:2px 2px #0000001f}.filter-strip.is-compact .filter-card{border-radius:16px;gap:0;padding:6px}.filter-strip.is-compact .filter-card-image{aspect-ratio:1/1.24;border-radius:12px}.filter-strip.is-compact .filter-card-badge{width:22px;height:22px;font-size:.78rem;top:6px;left:6px}.filter-card-name{font-size:1.05rem;font-weight:700}.filter-card-copy{color:#2f3542bd;font-size:.9rem}.admin-header-main{gap:10px;display:grid}.admin-nav{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.admin-nav-link{border:2px solid var(--ink);color:var(--ink);background:#ffffffd1;border-radius:999px;justify-content:center;align-items:center;padding:9px 14px;font-weight:700;text-decoration:none;display:inline-flex}.admin-nav-link.is-active{background:var(--neon-blue);color:#fff}.admin-filter-lab{overflow:visible}.admin-filter-layout{grid-template-columns:minmax(260px,.9fr) minmax(0,1.4fr);align-items:start;gap:18px;display:grid}.admin-filter-list{gap:12px;display:grid}.admin-filter-card{background:#ffffffd6;border:2px solid #2f354229;border-radius:20px;grid-template-columns:78px minmax(0,1fr);gap:12px;padding:12px;display:grid}.admin-filter-card.is-selected{border-color:var(--neon-blue);box-shadow:0 0 0 4px #70a1ff29}.admin-filter-card-image{aspect-ratio:3/4;object-fit:cover;background:#fff;border:2px solid #2f35421f;border-radius:16px;width:78px}.admin-filter-card-copy{gap:6px;display:grid}.admin-filter-card-copy p{color:#2f3542bd;margin:0;font-size:.92rem}.admin-filter-card-name{color:var(--ink);font-size:1.05rem;font-weight:700}.admin-filter-card-actions{flex-wrap:wrap;grid-column:1/-1;justify-content:space-between;align-items:center;gap:8px;display:flex}.admin-filter-order-actions{align-items:center;gap:6px;display:flex}.admin-filter-card-btn,.admin-filter-preview-reset{font:inherit;color:var(--ink);border:2px solid var(--ink);cursor:pointer;background:#ffffffeb;border-radius:999px;padding:9px 12px;font-weight:700}.admin-filter-editor{background:#ffffffb8;border:2px solid #2f354229;border-radius:24px;gap:16px;padding:18px;display:grid}.admin-filter-editor-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-filter-editor-kicker{color:var(--pop-red);letter-spacing:.06em;text-transform:uppercase;font-size:.85rem;font-weight:700}.admin-filter-editor-title{margin:4px 0 0;font-size:1.6rem}.admin-filter-preview-panel{grid-template-columns:minmax(0,1fr) 220px;align-items:start;gap:14px;display:grid}.admin-filter-preview-canvas{border:3px solid var(--ink);background:#fffffff5;border-radius:26px;width:100%;height:auto;display:block}.admin-filter-preview-tools{gap:10px;display:grid}.admin-filter-preview-note{color:#2f3542a8;margin:0;font-size:.9rem;line-height:1.45}.admin-filter-field-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:12px;display:grid}.admin-field-wide{grid-column:auto}.admin-filter-textarea{border:2px solid var(--ink);width:100%;max-width:100%;min-height:90px;font:inherit;resize:vertical;background:#fff;border-radius:14px;padding:12px 14px}.admin-filter-control-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.admin-filter-control{background:#fffaf0d1;border:2px solid #2f35421f;border-radius:18px;gap:8px;padding:12px;display:grid}.admin-filter-control-head{color:var(--ink);justify-content:space-between;align-items:center;gap:10px;font-weight:700;display:flex}.admin-filter-control-value{text-align:right;color:#2f3542bd;min-width:48px}.admin-filter-range{width:100%}.admin-filter-editor-actions{flex-wrap:wrap;justify-content:flex-start;gap:10px;display:flex}#how-to-modal{z-index:1000;justify-content:center;align-items:center;min-height:100dvh;padding:16px;display:flex;position:fixed;inset:0}#how-to-modal .how-to-backdrop{background:#00000061;position:absolute;inset:0}#how-to-modal .how-to-dialog{background:var(--paper);border:3px solid var(--ink);filter:url(#squiggly-0);border-radius:24px;width:100%;max-width:400px;max-height:calc(100vh - 32px);animation:.3s linear infinite squiggly-anim;position:relative;overflow-y:auto;box-shadow:8px 8px #0003}#how-to-modal .how-to-header{border-bottom:2px dashed #2f354233;justify-content:space-between;align-items:center;gap:12px;padding:18px 18px 10px;display:flex}#how-to-modal .how-to-title{color:var(--pop-red);margin:0;font-family:Rubik Doodle Shadow,cursive;font-size:1.5rem;line-height:1.1}#how-to-modal .how-to-close{border:2px solid var(--ink);width:40px;height:40px;color:var(--ink);cursor:pointer;background:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;padding:0;transition:transform .2s,background .2s,color .2s;display:inline-flex}#how-to-modal .how-to-close:hover{background:var(--pop-red);color:#fff;transform:rotate(90deg)}#how-to-modal .how-to-content{gap:14px;padding:18px;display:grid}#how-to-modal .how-to-step{border:2px solid var(--ink);background:#ffffffe6;border-radius:18px;align-items:center;gap:12px;padding:12px;transition:transform .2s;display:flex}#how-to-modal .how-to-step:hover{transform:translate(4px)}#how-to-modal .how-to-icon{border:2px solid var(--ink);background:var(--neon-blue);color:#fff;border-radius:14px;flex:0 0 52px;justify-content:center;align-items:center;width:52px;height:52px;display:inline-flex}#how-to-modal .how-to-icon svg{width:32px;height:32px}#how-to-modal .how-to-text{min-width:0;color:var(--ink);align-items:center;gap:8px;font-size:1.05rem;font-weight:700;line-height:1.2;display:flex}#how-to-modal .how-to-number{border:2px solid var(--ink);background:var(--doodle-yellow);width:28px;height:28px;color:var(--ink);border-radius:999px;flex:0 0 28px;justify-content:center;align-items:center;font-size:.9rem;font-weight:800;display:inline-flex}#how-to-modal .how-to-footer{justify-content:center;padding:0 18px 18px;display:flex}#how-to-modal .how-to-ok-btn{border:2px solid var(--ink);background:var(--pop-red);color:#fff;min-height:48px;font:inherit;box-shadow:3px 3px 0 var(--ink);cursor:pointer;border-radius:16px;padding:12px 28px;font-size:1.05rem;font-weight:700;transition:transform .15s,box-shadow .15s}#how-to-modal .how-to-ok-btn:hover{box-shadow:4px 4px 0 var(--ink);transform:translateY(-2px)}#how-to-modal .how-to-ok-btn:active{box-shadow:2px 2px 0 var(--ink);transform:translateY(1px)}@media (width<=520px){#how-to-modal{padding:10px}#how-to-modal .how-to-dialog{max-width:none;max-height:calc(100vh - 20px)}#how-to-modal .how-to-text{font-size:1rem}}@media (width>=901px){.frame-page-container{padding-top:30px}.frame-list{scrollbar-width:auto}.frame-list::-webkit-scrollbar{width:8px}.frame-list::-webkit-scrollbar-thumb{background:#2f354233;border-radius:999px}}@media (width<=1100px){.admin-upload-form{grid-template-columns:1fr 1fr}}@media (width<=900px){.camera-control-row{grid-template-columns:1fr}.camera-upload-controls{flex-direction:column;align-items:stretch}.camera-start-btn{width:100%}.camera-result-secondary-actions,.admin-upload-form{grid-template-columns:1fr}.admin-upload-form>*{min-width:0}.admin-card-header-row{flex-direction:column;align-items:stretch}.admin-frame-grid,.admin-filter-layout,.admin-filter-preview-panel,.admin-filter-field-grid,.admin-filter-control-grid{grid-template-columns:1fr}.frame-detail-shell,.camera-result-shell{width:calc(100% - 20px)}}@media (width<=640px){.camera-page-shell{width:calc(100% - 20px)}.camera-header{padding:14px 16px}.camera-stage-card{padding:10px}.camera-filter-dock{padding:8px}.camera-crop-modal{padding:14px}.camera-crop-dialog{gap:14px;padding:16px}.camera-crop-header{flex-direction:column}.camera-crop-close,.camera-crop-actions .whimsy-btn{width:100%}.camera-shot-progress{font-size:.92rem;top:10px}.camera-countdown{width:72px;height:72px;font-size:2.2rem}.admin-header{flex-direction:column}.admin-header-actions{justify-content:space-between;width:100%}.admin-page-shell{width:calc(100% - 20px);margin:10px;padding:18px 14px 28px}.admin-frame-title-row,.admin-filter-editor-head{flex-direction:column}}
