@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;700;800&family=Noto+Sans+JP:wght@400;500;700;900&display=swap";:root{--bg-color:#f8fafc;--surface-color:#fff;--text-primary:#0f172a;--text-secondary:#64748b;--accent-color:#f43f5e;--accent-light:#ffe4e6;--border-color:#e2e8f0;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 25px -3px #0000000d, 0 4px 6px -2px #00000006;--shadow-xl:0 20px 40px -5px #00000014;--shadow-float:0 25px 50px -12px #f43f5e40}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;height:100vh;font-family:Plus Jakarta Sans,Noto Sans JP,sans-serif;position:relative;overflow:hidden}body:before,body:after{content:"";filter:blur(120px);z-index:-1;opacity:.6;pointer-events:none;border-radius:50%;position:fixed}body:before{background:#f43f5e26;width:50vw;height:50vw;top:-10vw;left:-10vw}body:after{background:#38bdf826;width:60vw;height:60vw;bottom:-15vw;right:-10vw}.auth-wrapper{justify-content:center;align-items:center;height:100vh;padding:1.5rem;display:flex}.auth-card{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);box-shadow:var(--shadow-xl);background:#ffffffd9;border:1px solid #fff6;border-radius:32px;width:100%;max-width:440px;padding:3.5rem 2.5rem}.dashboard-layout{flex-direction:column;min-width:1400px;height:100vh;min-height:950px;display:flex;overflow:auto}.dashboard-header{-webkit-backdrop-filter:blur(20px);z-index:50;box-shadow:var(--shadow-sm);background:#ffffffb3;border-bottom:1px solid #fff6;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;height:75px;padding:1rem 2rem;display:flex}.admin-split-layout{flex-shrink:0;gap:2rem;width:1400px;height:875px;margin:0 auto;display:flex}.left-settings-panel{flex:1.3;min-width:650px;height:100%;max-height:calc(100vh - 75px);padding:2rem 1.5rem 4rem;overflow-y:auto}.left-settings-panel::-webkit-scrollbar{width:6px}.left-settings-panel::-webkit-scrollbar-track{background:0 0}.left-settings-panel::-webkit-scrollbar-thumb{background:#00000026;border-radius:10px}.left-settings-panel::-webkit-scrollbar-thumb:hover{background:#0000004d}.right-preview-panel{flex-direction:column;flex:1;min-width:380px;height:100%;padding:2rem 1.5rem;display:flex}.preview-sticky{flex-direction:column;height:100%;display:flex;overflow:hidden}.phone-mockup{aspect-ratio:9/19.5;background:#000;border:10px solid #1e293b;border-radius:40px;flex-direction:column;flex-shrink:0;width:auto;height:100%;max-height:100%;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 2px #d1d5db,0 25px 50px -12px #00000080}.phone-notch{z-index:100;background:#1e293b;border-bottom-right-radius:16px;border-bottom-left-radius:16px;width:40%;height:25px;position:absolute;top:0;left:50%;transform:translate(-50%)}.dash-card{background:var(--surface-color);box-shadow:var(--shadow-md);border:1px solid #00000005;border-radius:24px;margin-bottom:2rem;padding:2rem}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.1rem;font-weight:800;display:flex}.form-group{flex-direction:column;gap:.6rem;margin-bottom:1.5rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:700}.form-input{background:var(--bg-color);border:1px solid var(--border-color);color:var(--text-primary);border-radius:16px;padding:1.1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.form-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 4px var(--accent-light);background:#fff;outline:none}select.form-input{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 1.2rem center;background-repeat:no-repeat;background-size:1em}input[type=range]{-webkit-appearance:none;background:0 0;width:100%;margin:8px 0}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{cursor:pointer;background:var(--border-color);border-radius:4px;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{background:var(--surface-color);border:3px solid var(--accent-color);cursor:pointer;-webkit-appearance:none;border-radius:50%;width:20px;height:20px;margin-top:-7px;box-shadow:0 2px 5px #0000001a}.frame-setting-panel{border:1px solid var(--border-color);background:var(--surface-color);border-radius:16px;margin-bottom:1rem;padding:1.5rem}button{cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:.5rem;font-family:inherit;font-weight:800;transition:all .2s;display:inline-flex}button:active{transform:scale(.96)}button:disabled{opacity:.5;pointer-events:none;filter:grayscale()}.btn-primary{background:var(--accent-color);color:#fff;padding:1.2rem 2rem;font-size:1.05rem;box-shadow:0 4px 15px #f43f5e4d}.btn-primary:hover{box-shadow:var(--shadow-float);background:#e11d48;transform:translateY(-2px)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;padding:1rem 1.5rem}.btn-secondary:hover{background:var(--bg-color);border-color:#cbd5e1}.btn-sm{border-radius:12px;padding:.6rem 1rem;font-size:.85rem}.camera-layout-root,.phone-screen-inner{background:#000;width:100%;max-width:480px;height:100dvh;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 0 40px #000c}.camera-ui-top{z-index:20;text-align:justify;color:#fff;box-sizing:border-box;background:#0006;border-radius:12px;padding:1rem;position:absolute;top:1rem;left:1rem;right:1rem}.camera-ui-top h1{text-shadow:none;overflow-wrap:break-word;margin:0;padding-right:1rem;font-size:.85rem;font-weight:800;line-height:1.2}.camera-ui-top p{opacity:.9;text-shadow:none;overflow-wrap:break-word;text-justify:inter-character;margin:.2rem 0 0;font-size:.7rem;font-weight:500;line-height:1.4}.camera-viewport-wrapper{justify-content:center;align-items:center;width:100%;height:100%;transition:all .4s cubic-bezier(.2,.8,.2,1);display:flex;position:absolute;top:0;left:0;overflow:hidden}.camera-viewport-wrapper.has-result{height:calc(100% - 110px);padding:1rem 1.5rem}.camera-aspect-container{justify-content:center;align-items:center;width:100%;max-width:100%;max-height:100%;transition:border-radius .4s;display:flex;position:relative;overflow:hidden}.camera-viewport-wrapper.has-result .camera-aspect-container{border-radius:20px;box-shadow:0 10px 30px #0006}.camera-video{object-fit:cover;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0;transform:scaleX(-1)}.captured-image{object-fit:contain;z-index:5;width:100%;height:100%;animation:.3s ease-out forwards captureFlash;position:absolute;top:0;left:0}.frame-composite-box{pointer-events:none;z-index:3;width:100%;height:100%;position:absolute;top:50%;left:50%}.frame-composite-img{object-fit:contain;width:100%;height:100%}.camera-ui-bottom{z-index:20;pointer-events:none;background:0 0;flex-direction:column;align-items:center;gap:1rem;padding:0 1.5rem 15px;transition:all .4s cubic-bezier(.2,.8,.2,1);display:flex;position:absolute;bottom:0;left:0;right:0}.camera-ui-bottom.result-mode{background:#fff;border-top:1px solid #e2e8f0;flex-direction:row;justify-content:center;align-items:center;gap:.8rem;height:110px;padding:1rem}.camera-ui-bottom>*{pointer-events:auto}.camera-shutter{cursor:pointer;aspect-ratio:1;box-sizing:border-box;background:#00000026;border:2px solid #ffffffe6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto;padding:4px;transition:transform .2s;display:flex;box-shadow:0 4px 12px #00000026}.camera-shutter-inner{box-sizing:border-box;background:#fff;border-radius:50%;width:100%;height:100%;transition:all .15s;box-shadow:0 2px 6px #0003}.camera-shutter:active{transform:scale(.95)}.camera-shutter:active .camera-shutter-inner{background:#e2e8f0;transform:scale(.9)}.camera-btn-icon{color:#fff;cursor:pointer;background:#00000026;border:none;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;padding:0;transition:transform .2s,opacity .2s;display:flex;box-shadow:0 4px 12px #00000026}.camera-btn-icon:active{background:#0000004d;transform:scale(.85)}.camera-btn-icon:disabled{opacity:.2;pointer-events:none}.camera-frame-nav{z-index:20;color:#fff;cursor:pointer;background:#00000026;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 12px #00000026}.camera-frame-nav:active{background:#0000004d;transform:translateY(-50%)scale(.9)}.camera-frame-nav.left{left:5px}.camera-frame-nav.right{right:5px}.camera-btn-action{cursor:pointer;white-space:nowrap;border:none;border-radius:30px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.8rem;font-family:inherit;font-size:.9rem;font-weight:800;transition:opacity .2s;display:flex}.camera-btn-action:active{opacity:.8}.camera-btn-cancel{color:#475569;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:none;border-radius:30px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.8rem;font-size:.9rem;font-weight:700;display:flex}.album-fab{z-index:30;background:var(--accent-color);cursor:pointer;border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s;display:flex;position:absolute;bottom:2rem;right:1.5rem;box-shadow:0 4px 15px #00000040}.album-fab:active{transform:scale(.9)}.album-fab svg{color:#fff}.album-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;font-size:.75rem;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 5px #0000004d}.album-modal-overlay{z-index:60;background:#f8fafcfa;flex-direction:column;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.album-modal-header{padding:.6rem 1rem;padding-top:calc(env(safe-area-inset-top,20px) + 8px);background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;display:flex;box-shadow:0 2px 10px #00000005}.album-modal-header h2{color:#0f172a;margin:0;font-size:.95rem;font-weight:800}.album-grid{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;flex-direction:row;flex:1;align-items:stretch;gap:.8rem;padding:.4rem 1rem;display:flex;overflow:auto hidden}.album-item{aspect-ratio:9/16;cursor:pointer;scroll-snap-align:center;background:#e2e8f0;border:2px solid #0000;border-radius:8px;flex-shrink:0;height:100%;transition:all .2s;position:relative;overflow:hidden}.album-item img{object-fit:contain;background:#000;width:100%;height:100%}.album-item.selected{border-color:var(--accent-color);opacity:.9;transform:scale(.96)}.album-item-check{background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute;top:.3rem;right:.3rem;box-shadow:0 2px 6px #0000004d}.album-item.selected .album-item-check{background:var(--accent-color);color:#fff}.album-item:not(.selected) .album-item-check svg{opacity:0}.album-modal-footer{padding:.8rem 1rem calc(env(safe-area-inset-bottom,15px) + .8rem);background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -4px 20px #0000000d}.album-modal-footer-actions{flex-direction:column;gap:.6rem;display:flex}@keyframes captureFlash{0%{filter:brightness(3)contrast(1.5);opacity:0;transform:scale(.98)}to{filter:brightness()contrast();opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-overlay{z-index:9999;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000b3;justify-content:center;align-items:center;padding:2rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.toast-card{box-shadow:var(--shadow-xl);text-align:center;color:#0f172a;background:#fff;border-radius:32px;width:100%;max-width:400px;padding:2.5rem 2rem}.form-group.select-open .select-arrow-icon svg{transform:rotate(180deg)}.select-arrow-icon svg{transition:transform .2s cubic-bezier(.4,0,.2,1)}
