:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}*,*:before,*:after{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.modal-overlay[data-v-75aeed8b]{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;justify-content:center;align-items:center;padding:16px}.modal-container[data-v-75aeed8b]{background:#fff;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden;animation:popIn-75aeed8b .3s ease-out}@keyframes popIn-75aeed8b{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.pdpa-header[data-v-75aeed8b]{background:#004a8d;padding:16px 24px;text-align:center;flex-shrink:0}.pdpa-title[data-v-75aeed8b]{color:#fff;font-size:1.05rem;font-weight:700;margin:0}.pdpa-body[data-v-75aeed8b]{padding:20px 24px;overflow-y:auto;flex:1;font-size:.86rem;color:#4b5563;line-height:1.65;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f1f1}.pdpa-body[data-v-75aeed8b]::-webkit-scrollbar{width:5px}.pdpa-body[data-v-75aeed8b]::-webkit-scrollbar-track{background:#f1f1f1}.pdpa-body[data-v-75aeed8b]::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.pdpa-section[data-v-75aeed8b]{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.pdpa-section[data-v-75aeed8b]:last-of-type{border-bottom:none}.pdpa-body h4[data-v-75aeed8b]{color:#004a8d;font-weight:700;font-size:.92rem;margin:0 0 5px}.pdpa-body p[data-v-75aeed8b]{margin:0}.pdpa-updated[data-v-75aeed8b]{font-size:.7rem;color:#9ca3af;font-style:italic;text-align:center;margin-top:14px}.pdpa-footer[data-v-75aeed8b]{padding:18px 24px;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}.check-label[data-v-75aeed8b]{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;cursor:pointer}.check-input[data-v-75aeed8b]{width:17px;height:17px;margin-top:2px;accent-color:#004a8d;cursor:pointer;flex-shrink:0}.check-text[data-v-75aeed8b]{font-size:.83rem;color:#374151;line-height:1.5}.footer-btns[data-v-75aeed8b]{display:flex;gap:10px}.btn-reject[data-v-75aeed8b]{flex:1;padding:12px;border:1.5px solid #e5e7eb;border-radius:8px;background:#fff;color:#555;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .2s;min-height:46px}.btn-reject[data-v-75aeed8b]:hover{background:#f3f4f6}.btn-accept[data-v-75aeed8b]{flex:1;padding:12px;border:none;border-radius:8px;background:#cbd5e1;color:#fff;font-size:.88rem;font-weight:700;cursor:not-allowed;transition:all .2s;min-height:46px}.btn-accept--on[data-v-75aeed8b]{background:#004a8d;cursor:pointer;box-shadow:0 4px 12px #004a8d40}.btn-accept--on[data-v-75aeed8b]:hover{background:#003a6e}.btn-accept--on[data-v-75aeed8b]:active{transform:scale(.97)}.modal-enter-active[data-v-75aeed8b]{transition:opacity .25s ease}.modal-leave-active[data-v-75aeed8b]{transition:opacity .2s ease}.modal-enter-from[data-v-75aeed8b],.modal-leave-to[data-v-75aeed8b]{opacity:0}@media(max-width:600px){.modal-overlay[data-v-75aeed8b]{padding:0;align-items:flex-end}.modal-container[data-v-75aeed8b]{max-width:100%;border-radius:20px 20px 0 0;max-height:92vh}.pdpa-body[data-v-75aeed8b]{max-height:44vh;padding:14px 16px;font-size:.82rem}.pdpa-header[data-v-75aeed8b]{padding:13px 18px}.pdpa-footer[data-v-75aeed8b]{padding:14px 16px}.btn-reject[data-v-75aeed8b],.btn-accept[data-v-75aeed8b]{min-height:50px;font-size:.9rem}}.camera-overlay[data-v-8234d00d]{position:fixed;inset:0;z-index:9999;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-video-wrap[data-v-8234d00d]{position:relative;width:100%;max-width:640px;aspect-ratio:4/3;overflow:hidden;border-radius:12px}.camera-video-wrap video[data-v-8234d00d]{width:100%;height:100%;object-fit:cover;display:block}.camera-video-wrap canvas[data-v-8234d00d]{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.camera-status-bar[data-v-8234d00d]{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:8px}.camera-status-text[data-v-8234d00d]{color:#fff;font-size:1rem;font-weight:500;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.6);min-height:1.5em}.camera-status-text.detected[data-v-8234d00d]{color:#4caf50;font-weight:700;animation:pulse-green-8234d00d .8s ease infinite alternate}@keyframes pulse-green-8234d00d{0%{opacity:.8}to{opacity:1;text-shadow:0 0 12px rgba(76,175,80,.7)}}.camera-countdown[data-v-8234d00d]{font-size:2.4rem;font-weight:800;color:#4caf50;text-shadow:0 0 20px rgba(76,175,80,.6);animation:pop-8234d00d .3s ease}@keyframes pop-8234d00d{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.camera-btn-row[data-v-8234d00d]{margin-top:20px;display:flex;gap:12px}.camera-btn[data-v-8234d00d]{padding:12px 28px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.camera-btn.close[data-v-8234d00d]{background:#ffffff26;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.camera-btn.close[data-v-8234d00d]:hover{background:#ffffff40}.camera-btn.capture[data-v-8234d00d]{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;box-shadow:0 4px 14px #4caf5066}.camera-btn.capture[data-v-8234d00d]:hover{transform:translateY(-1px);box-shadow:0 6px 18px #4caf5080}.camera-btn.capture[data-v-8234d00d]:disabled{opacity:.5;cursor:not-allowed;transform:none}.camera-flash[data-v-8234d00d]{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:10;animation:flash-anim-8234d00d .4s ease}@keyframes flash-anim-8234d00d{0%{opacity:.8}to{opacity:0}}.camera-processing[data-v-8234d00d]{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:20;border-radius:12px}.camera-processing .spinner-cam[data-v-8234d00d]{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:#4caf50;border-radius:50%;animation:spin-8234d00d .8s linear infinite}@keyframes spin-8234d00d{to{transform:rotate(360deg)}}.camera-processing p[data-v-8234d00d]{color:#fff;font-size:.95rem}.reg-page[data-v-1d616a16]{display:flex;flex-direction:column;min-height:100%}.reg-header[data-v-1d616a16]{background:linear-gradient(#25222280,#00000080),url(../public/backgrounds/ground/ground_1.png);background-size:cover;background-position:center;padding:20px 24px;text-align:center;color:#fff;padding-bottom:4 0px}.reg-title[data-v-1d616a16]{margin:0 0 4px;font-size:1.3rem;font-weight:800}.reg-sub[data-v-1d616a16]{margin:0;font-size:.85rem;opacity:.85}.reg-body[data-v-1d616a16]{flex:1;max-width:560px;width:100%;margin:0 auto;padding:24px 20px;display:flex;flex-direction:column;gap:20px}.upload-section[data-v-1d616a16]{width:100%}.upload-choice[data-v-1d616a16]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.upload-choice .upload-drop-zone[data-v-1d616a16]{aspect-ratio:1/1}.upload-alt[data-v-1d616a16]{background:#f5f0e8!important;border-color:#d4c9a8!important}.upload-alt[data-v-1d616a16]:hover{background:#efe8da!important;border-color:#bfb48e!important}.upload-alt .upload-text[data-v-1d616a16]{color:#7d6b3a!important}.preview-btn-row[data-v-1d616a16]{position:absolute;top:10px;right:10px;display:flex;gap:6px}@media(max-width:380px){.upload-choice[data-v-1d616a16]{grid-template-columns:1fr}}.hidden-input[data-v-1d616a16]{display:none}.upload-drop-zone[data-v-1d616a16]{width:100%;aspect-ratio:4/3;border:2px dashed #b0c4de;border-radius:16px;background:#f0f5fc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .25s,background .25s}.upload-drop-zone[data-v-1d616a16]:hover{border-color:#2a5298;background:#e8effa}.upload-icon[data-v-1d616a16]{font-size:2.8rem}.upload-text[data-v-1d616a16]{margin:0;font-size:1rem;font-weight:700;color:#2a5298}.upload-hint[data-v-1d616a16]{margin:0;font-size:.78rem;color:#999}.preview-box[data-v-1d616a16]{position:relative;width:100%}.preview-img[data-v-1d616a16]{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;border:2px solid #2a5298;display:block}.change-btn[data-v-1d616a16]{position:absolute;top:10px;right:10px;background:#0000008c;color:#fff;border:none;border-radius:20px;padding:6px 14px;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .2s}.change-btn[data-v-1d616a16]:hover{background:#000000bf}.reg-form[data-v-1d616a16]{display:flex;flex-direction:column;gap:14px}.input-group[data-v-1d616a16]{display:flex;flex-direction:column;gap:6px}.input-group label[data-v-1d616a16]{font-size:.88rem;font-weight:600;color:#555;margin-left:4px}.req[data-v-1d616a16]{color:#e53e3e}.custom-input[data-v-1d616a16]{width:100%;padding:14px 18px;border-radius:14px;border:1px solid #e1e1e1;background:#fff;font-size:1rem;color:#333;outline:none;transition:border-color .25s,box-shadow .25s}.custom-input[data-v-1d616a16]:focus{border-color:#2a5298;box-shadow:0 0 0 3px #2a52981a}.custom-input--select[data-v-1d616a16]{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:46px;border-color:#b9c9e8;background-image:linear-gradient(0deg,#fffffff2,#fffffff2),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232a5298' stroke-width='2.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 14px center;background-size:auto,14px 14px}.custom-input--select[data-v-1d616a16]:hover{border-color:#96b2e2}.custom-input--select[data-v-1d616a16]:invalid{color:#8d97a9}.custom-input--select option[data-v-1d616a16]{color:#1b2b49;background:#fff}.field-hint[data-v-1d616a16]{font-size:.76rem;color:#e57a00;margin-left:4px}.pdpa-row[data-v-1d616a16]{display:flex;align-items:flex-start;gap:10px;cursor:pointer;padding:12px 14px;border-radius:12px;border:1px solid #e0e7ff;background:#f5f7ff;transition:background .2s;-webkit-user-select:none;user-select:none}.pdpa-row[data-v-1d616a16]:hover{background:#eef1ff}.pdpa-check-box[data-v-1d616a16]{min-width:22px;height:22px;border-radius:6px;border:2px solid #2a5298;background:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#2a5298;transition:background .2s;flex-shrink:0;margin-top:1px}.pdpa-check-box.checked[data-v-1d616a16]{background:#2a5298;color:#fff}.pdpa-text[data-v-1d616a16]{font-size:.85rem;color:#444;line-height:1.5}.pdpa-link[data-v-1d616a16]{color:#2a5298;font-weight:600;text-decoration:underline}.queue-box[data-v-1d616a16]{background:#eef3ff;border:1px solid #c8d8f8;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}.queue-spinner-row[data-v-1d616a16]{display:flex;align-items:center;gap:10px}.spinner-queue[data-v-1d616a16]{width:20px;height:20px;border:2.5px solid rgba(42,82,152,.2);border-top-color:#2a5298;border-radius:50%;animation:spin-1d616a16 .65s linear infinite;flex-shrink:0}@keyframes spin-1d616a16{to{transform:rotate(360deg)}}.queue-label[data-v-1d616a16]{font-size:.9rem;font-weight:600;color:#1e3c72}.queue-detail[data-v-1d616a16]{display:flex;flex-direction:column;gap:6px}.queue-bar-bg[data-v-1d616a16]{width:100%;height:8px;border-radius:10px;background:#d4dfef;overflow:hidden}.queue-bar-fill[data-v-1d616a16]{height:100%;border-radius:10px;background:linear-gradient(90deg,#2a5298,#4a90d9);transition:width .5s ease}.queue-pos[data-v-1d616a16]{font-size:.78rem;color:#555;text-align:right}.status-msg[data-v-1d616a16]{margin:0;padding:10px 14px;border-radius:10px;font-size:.88rem;font-weight:600}.status-msg.success[data-v-1d616a16]{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.status-msg.error[data-v-1d616a16]{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-row[data-v-1d616a16]{display:flex;gap:10px;margin-top:4px}.search-btn[data-v-1d616a16]{flex:1;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;border:none;border-radius:14px;padding:14px;font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;box-shadow:0 6px 18px #2a529840;transition:transform .15s,opacity .2s}.search-btn[data-v-1d616a16]:active:not(:disabled){transform:scale(.96)}.search-btn[data-v-1d616a16]:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.ghost-btn[data-v-1d616a16]{background:#fff;color:#1e3c72;border:1.5px solid #c8d6f3;box-shadow:none}.spinner[data-v-1d616a16]{width:15px;height:15px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-1d616a16 .6s linear infinite}@media(max-width:480px){.reg-body[data-v-1d616a16]{padding:16px 14px}.reg-title[data-v-1d616a16]{font-size:1.1rem}}.bgpicker-overlay[data-v-e4f7b053]{position:fixed;inset:0;z-index:1100;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px}.bgpicker-container[data-v-e4f7b053]{background:#fff;border-radius:20px;width:min(96vw,900px);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px #00000040}.bgpicker-header[data-v-e4f7b053]{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #efefef;flex-shrink:0}.bgpicker-title[data-v-e4f7b053]{margin:0;font-size:1.05rem;font-weight:700;color:#222}.bgpicker-close[data-v-e4f7b053]{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#888;padding:4px 8px;border-radius:8px;transition:background .15s}.bgpicker-close[data-v-e4f7b053]:hover{background:#f0f0f0}.bgpicker-body[data-v-e4f7b053]{display:flex;gap:0;flex:1;overflow:hidden}.bgpicker-left[data-v-e4f7b053]{width:200px;flex-shrink:0;padding:16px;border-right:1px solid #efefef;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.type-badge[data-v-e4f7b053]{display:inline-block;padding:4px 14px;border-radius:20px;font-size:.82rem;font-weight:700;text-align:center;width:fit-content}.type-badge.sky[data-v-e4f7b053]{background:#e0f2fe;color:#0369a1}.type-badge.ground[data-v-e4f7b053]{background:#dcfce7;color:#15803d}.type-badge.water[data-v-e4f7b053]{background:#dbeafe;color:#1d4ed8}.bg-instruction[data-v-e4f7b053]{margin:0;font-size:.82rem;color:#888;font-weight:600}.no-bg-hint[data-v-e4f7b053]{font-size:.78rem;color:#b45309;background:#fef3c7;border-radius:10px;padding:10px;text-align:center;line-height:1.6}.no-bg-hint code[data-v-e4f7b053]{font-size:.72rem;color:#92400e}.bg-list[data-v-e4f7b053]{display:flex;flex-direction:column;gap:8px}.bg-thumb-wrap[data-v-e4f7b053]{cursor:pointer;border-radius:10px;border:2.5px solid transparent;overflow:hidden;transition:border-color .15s,box-shadow .15s}.bg-thumb-wrap[data-v-e4f7b053]:hover{border-color:#94a3b8}.bg-thumb-wrap.selected[data-v-e4f7b053]{border-color:#6366f1;box-shadow:0 0 0 2px #6366f140}.bg-thumb[data-v-e4f7b053]{width:100%;aspect-ratio:1.414/1;object-fit:cover;display:block}.bg-none-preview[data-v-e4f7b053]{width:100%;aspect-ratio:1.414/1;display:flex;align-items:center;justify-content:center;background:repeating-conic-gradient(#ccc 0% 25%,#eee 0% 50%) 0 0 / 16px 16px;font-size:1.8rem}.bg-thumb-label[data-v-e4f7b053]{text-align:center;font-size:.72rem;padding:4px 4px 6px;color:#555;background:#f8f8f8}.none-option[data-v-e4f7b053]{margin-top:4px}.bgpicker-right[data-v-e4f7b053]{flex:1;padding:16px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.canvas-wrap[data-v-e4f7b053]{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:12px;overflow:hidden;min-height:0}.preview-canvas[data-v-e4f7b053]{max-width:100%;max-height:100%;object-fit:contain;display:block;border-radius:8px;box-shadow:0 4px 16px #0000001f}.canvas-loading[data-v-e4f7b053]{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#ffffffa6;border-radius:12px}.bgpicker-actions[data-v-e4f7b053]{display:flex;gap:10px;flex-shrink:0}.dl-btn[data-v-e4f7b053]{flex:1;padding:12px 16px;border-radius:12px;border:none;cursor:pointer;font-size:1rem;font-weight:700;background:#6366f1;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,opacity .15s}.dl-btn[data-v-e4f7b053]:hover:not(:disabled){background:#4f46e5}.dl-btn[data-v-e4f7b053]:disabled{opacity:.5;cursor:not-allowed}.dl-btn.ghost-btn[data-v-e4f7b053]{background:#f1f5f9;color:#475569}.dl-btn.ghost-btn[data-v-e4f7b053]:hover:not(:disabled){background:#e2e8f0}.spinner[data-v-e4f7b053]{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin-e4f7b053 .7s linear infinite}.spinner-sm[data-v-e4f7b053]{width:14px;height:14px}.spinner-lg[data-v-e4f7b053]{width:32px;height:32px;border-width:3px;border-color:#6366f14d;border-top-color:#6366f1}@keyframes spin-e4f7b053{to{transform:rotate(360deg)}}.modal-enter-active[data-v-e4f7b053]{transition:opacity .2s ease,transform .2s ease}.modal-leave-active[data-v-e4f7b053]{transition:opacity .15s ease,transform .15s ease}.modal-enter-from[data-v-e4f7b053],.modal-leave-to[data-v-e4f7b053]{opacity:0;transform:scale(.96)}@media(max-width:600px){.bgpicker-container[data-v-e4f7b053]{width:92vw;max-height:90vh;border-radius:16px}.bgpicker-header[data-v-e4f7b053]{padding:14px 16px}.bgpicker-title[data-v-e4f7b053]{font-size:1rem}.bgpicker-body[data-v-e4f7b053]{flex-direction:column;overflow-y:auto;overflow-x:hidden}.bgpicker-right[data-v-e4f7b053]{display:contents}.canvas-wrap[data-v-e4f7b053]{order:1;margin:16px 16px 0;min-height:250px;max-height:45vh;flex:none}.bgpicker-left[data-v-e4f7b053]{order:2;width:100%;border-right:none;border-bottom:none;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;padding:12px 16px;gap:12px;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0}.bgpicker-left[data-v-e4f7b053]::-webkit-scrollbar{display:none}.bg-list[data-v-e4f7b053]{flex-direction:row;gap:12px;display:flex}.bg-thumb-wrap[data-v-e4f7b053],.none-option[data-v-e4f7b053]{width:90px;min-width:90px;flex-shrink:0;margin-top:0;display:flex;flex-direction:column}.bg-thumb-label[data-v-e4f7b053]{font-size:.7rem}.type-badge[data-v-e4f7b053],.bg-instruction[data-v-e4f7b053]{display:none}.bgpicker-actions[data-v-e4f7b053]{order:3;padding:12px 16px 16px;flex-shrink:0}.dl-btn[data-v-e4f7b053]{padding:12px 14px;font-size:.95rem}}body,html,#app{margin:0!important;padding:0!important;width:100%!important;max-width:100%!important;background-color:#eeeff0!important;place-items:start!important;overflow-x:hidden}*{box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app-container{min-height:100vh;width:100%;display:flex;flex-direction:column}.header{position:fixed;top:0;left:0;width:100%;display:flex;justify-content:center;align-items:center;background-image:url(/backgrounds/ground/ground_1.png);background-size:cover;background-position:center;transition:all .8s cubic-bezier(.65,0,.05,1);z-index:50;box-shadow:0 25px 30px #0000003a}.header-splash{height:100vh}.header-ready{height:35vh}.logo{color:#fff;font-size:3.5rem;font-weight:800;display:flex;align-items:center;gap:15px}.logo-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:12px;background:#ffffff26;padding:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.logo-icon img{max-width:100%;max-height:100%;object-fit:contain}.main-content{padding-top:35vh;width:100%;flex:1}.fade-up-anim{opacity:0;transform:translateY(30px);animation:fadeUpEffect .6s forwards .2s}@keyframes fadeUpEffect{to{opacity:1;transform:translateY(0)}}.content-wrapper{max-width:600px;margin:0 auto;padding:40px 20px;display:flex;flex-direction:column;gap:20px}.section-title{color:#333;font-size:1.25rem;margin-bottom:10px;text-align:center}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:.9rem;font-weight:600;color:#555;margin-left:5px}.custom-input{width:100%;padding:16px 20px;border-radius:16px;border:1px solid #e1e1e1;background-color:#fff;color:#333;font-size:1rem;outline:none;transition:all .3s ease;box-shadow:0 2px 10px #00000005}.custom-input:focus{border-color:#2a5298;box-shadow:0 4px 15px #2a529826}.type-btn-group{display:flex;gap:10px;width:100%}.type-btn{flex:1;padding:14px 4px;border-radius:14px;border:1.5px solid #e1e1e1;background:#fff;color:#555;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px}.type-btn:hover{background:#f8fbff;border-color:#b9c9e8}.type-btn.active.sky{background:#38bdf826;color:#0284c7;border-color:#0284c7}.type-btn.active.ground{background:#34d39926;color:#059669;border-color:#059669}.type-btn.active.water{background:#60a5fa26;color:#2563eb;border-color:#2563eb}.btn-row{display:flex;gap:10px;margin-top:10px}.search-btn{flex:1;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;border:none;border-radius:16px;padding:16px;font-size:1rem;font-weight:700;display:flex;justify-content:center;align-items:center;gap:8px;cursor:pointer;box-shadow:0 8px 20px #2a52984d;transition:transform .2s,opacity .2s}.search-btn:active:not(:disabled){transform:scale(.96)}.search-btn:disabled{opacity:.6;cursor:not-allowed}.ghost-btn{background:#fff;color:#1e3c72;border:1px solid #c8d6f3;box-shadow:none}.panel-card{background:#fff;border:1px solid #e8eaf0;border-radius:16px;padding:16px}.panel-title{margin-top:0;margin-bottom:14px;color:#1e3c72}.option-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;justify-content:center;display:contents}.option-card{border:1px solid #d9e4ff;background:#fff;border-radius:16px;padding:18px;text-align:center;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.option-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px #1e3c721f}.option-icon{font-size:1.4rem;margin-bottom:6px}.option-title{font-size:1rem;font-weight:700;color:#1e3c72}.option-sub{font-size:.82rem;color:#6b7280;margin-top:4px}.upload-preview-wrap{margin-top:10px;width:100%;border:1px dashed #bfd0f4;border-radius:12px;padding:10px;background:#f8fbff}.upload-preview{width:100%;max-height:260px;object-fit:contain}.upload-message{margin-top:10px;margin-bottom:0;color:#1e3c72;font-size:.9rem;font-weight:600}.spinner{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-count{font-size:.9rem;color:#777;text-align:center;margin:0}.image-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}.image-card{width:260px;background:#fff;border-radius:16px;border:1px solid #e8eaf0;overflow:hidden;box-shadow:0 2px 12px #0000000a;transition:transform .2s,box-shadow .2s}.image-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.card-img-wrap{position:relative;width:100%;height:180px;background:#f0f2f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.card-img{max-width:100%;max-height:100%;object-fit:contain}.type-badge{position:absolute;top:8px;right:8px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.badge-sky{background:#38bdf826;color:#0284c7;border:1px solid rgba(56,189,248,.3)}.badge-ground{background:#34d39926;color:#059669;border:1px solid rgba(52,211,153,.3)}.badge-water{background:#60a5fa26;color:#2563eb;border:1px solid rgba(96,165,250,.3)}.card-body{padding:12px 14px}.card-creature{font-weight:700;font-size:1rem;color:#222;margin-bottom:4px}.card-drawer{font-size:.85rem;color:#666;margin-bottom:2px}.card-time{font-size:.75rem;color:#999;margin-bottom:10px}.download-btn{display:block;width:100%;text-align:center;padding:10px;border-radius:12px;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;font-size:.85rem;font-weight:600;text-decoration:none;transition:opacity .2s}.download-btn:hover{opacity:.85}.empty-state{text-align:center;padding:40px 0;color:#999}.empty-icon{font-size:3rem;margin-bottom:8px}.empty-hint{font-size:.8rem;color:#bbb;margin-top:4px}.carousel-section{padding:20px 0 10px;overflow:hidden}.carousel-title{text-align:center;font-size:1.2rem;color:#333;margin-bottom:14px}.carousel-track-wrapper{overflow:hidden;width:100%;position:relative;mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);display:flex;justify-content:flex-start}.carousel-track{display:flex;gap:14px;width:max-content;animation:scrollCarousel 20s linear infinite}.carousel-track:hover{animation-play-state:paused}@keyframes scrollCarousel{0%{transform:translate(0)}to{transform:translate(-50%)}}.carousel-card{flex-shrink:0;width:160px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 10px #0000000f;border:1px solid #e8eaf0;transition:transform .2s}.carousel-card:hover{transform:scale(1.05)}.carousel-img{width:100%;height:120px;object-fit:contain;background:#f0f2f5}.carousel-label{padding:6px 10px;font-size:.8rem;font-weight:600;color:#444;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;display:flex;justify-content:center;align-items:center;padding:16px;overflow-y:auto}.modal-container{background:#fff;border-radius:20px;width:100%;max-width:880px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #0000004d;overflow:hidden;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#1e3c72,#2a5298)}.modal-title{color:#fff;font-size:1.15rem;font-weight:700;margin:0}.modal-close{background:#fff3;border:none;color:#fff;font-size:1.2rem;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:#ffffff59}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-body .image-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}.modal-body .image-card{width:240px;background:#fff;border-radius:16px;border:1px solid #e8eaf0;overflow:hidden;box-shadow:0 2px 12px #0000000a;transition:transform .2s,box-shadow .2s}.modal-body .image-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.modal-body .card-img-wrap{position:relative;width:100%;height:160px;background:#f0f2f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.modal-body .card-img{max-width:100%;max-height:100%;object-fit:contain}.modal-body .type-badge{position:absolute;top:8px;right:8px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase}.modal-body .badge-sky{background:#38bdf826;color:#0284c7;border:1px solid rgba(56,189,248,.3)}.modal-body .badge-ground{background:#34d39926;color:#059669;border:1px solid rgba(52,211,153,.3)}.modal-body .badge-water{background:#60a5fa26;color:#2563eb;border:1px solid rgba(96,165,250,.3)}.modal-body .card-body{padding:12px 14px}.modal-body .card-creature{font-weight:700;font-size:1rem;color:#222;margin-bottom:4px}.modal-body .card-drawer{font-size:.85rem;color:#666;margin-bottom:2px}.modal-body .card-time{font-size:.75rem;color:#999;margin-bottom:10px}.modal-body .download-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;border:none;cursor:pointer;text-align:center;padding:10px;border-radius:12px;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;font-size:.85rem;font-weight:600;text-decoration:none;transition:opacity .2s,transform .15s}.modal-body .download-btn:active:not(:disabled){transform:scale(.96)}.modal-body .download-btn:disabled{opacity:.65;cursor:not-allowed}.modal-body .download-btn .spinner-dl{width:13px;height:13px;border-width:2px;border-color:#ffffff59;border-top-color:#fff;border-style:solid;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.modal-body .download-btn:hover{opacity:.85}.modal-body .empty-state{text-align:center;padding:40px 0;color:#999}.modal-body .empty-icon{font-size:3rem;margin-bottom:8px}.modal-body .empty-hint{font-size:.8rem;color:#bbb;margin-top:4px}.modal-loading{text-align:center;padding:60px 0;color:#777}.modal-loading .spinner{display:inline-block;width:32px;height:32px;border:3px solid rgba(42,82,152,.2);border-top-color:#2a5298;border-radius:50%;animation:spin .6s linear infinite;margin-bottom:12px}.option-modal{max-width:560px}.modal-enter-active{transition:opacity .3s ease}.modal-enter-active .modal-container{transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}.modal-leave-active{transition:opacity .2s ease}.modal-leave-active .modal-container{transition:transform .2s ease,opacity .2s ease}.modal-enter-from{opacity:0}.modal-enter-from .modal-container{opacity:0;transform:scale(.9) translateY(20px)}.modal-leave-to{opacity:0}.modal-leave-to .modal-container{opacity:0;transform:scale(.95) translateY(10px)}@media(max-width:900px){.header-ready{height:30vh}.main-content{padding-top:30vh}.modal-body .image-grid{gap:12px}.modal-body .image-card{width:200px}}@media(max-width:768px){.option-grid{grid-template-columns:1fr}.carousel-card{width:120px}.carousel-img{height:90px}.carousel-label{font-size:.72rem}.header-ready{height:28vh}.main-content{padding-top:28vh}.logo{font-size:2.8rem}.content-wrapper{padding:28px 16px;gap:16px}.section-title{font-size:1.1rem}.modal-overlay{padding:20px 10px}.modal-container{max-height:90vh;border-radius:16px}.modal-body{padding:16px}.modal-body .image-card{width:180px}}@media(max-width:600px){.header-ready{height:220px}.logo{font-size:2.2rem;letter-spacing:-.5px}.content-wrapper{padding:24px 14px;gap:14px}.section-title{font-size:1rem}.custom-input{padding:14px 16px;font-size:.95rem;border-radius:14px}.search-btn{padding:14px;font-size:.95rem;border-radius:14px}.carousel-section{padding:14px 0 8px}.carousel-title{font-size:1rem;margin-bottom:10px}.carousel-card{width:110px}.carousel-img{height:80px}.carousel-label{font-size:.68rem;padding:5px 8px}.modal-overlay{padding:12px}.modal-container{border-radius:16px;max-height:90vh}.modal-header{padding:14px 18px}.modal-title{font-size:1rem}.modal-body{padding:14px 12px}.modal-body .image-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;justify-items:center}.modal-body .image-card{width:100%}.modal-body .card-img-wrap{height:130px}}@media(max-width:400px){.header-ready{height:190px}.main-content{padding-top:190px}.logo{font-size:1.8rem}.content-wrapper{padding:20px 12px}.btn-row{flex-direction:column}.carousel-card{width:95px}.carousel-img{height:68px}.modal-body .image-grid{grid-template-columns:1fr 1fr;gap:8px}.modal-body .card-img-wrap{height:110px}.modal-body .card-creature{font-size:.88rem}}.register-overlay{position:fixed;inset:0;z-index:999;background:#f4f6f9;overflow-y:auto}.divider-row{display:flex;align-items:center;gap:10px;margin:4px 0}.divider-line{flex:1;height:1px;background:#d9e0ec}.divider-text{font-size:.82rem;color:#999;white-space:nowrap}.register-entry-btn{font-size:.95rem}.slide-up-enter-active{transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}.slide-up-leave-active{transition:transform .25s ease,opacity .2s ease}.slide-up-enter-from{transform:translateY(40px);opacity:0}.slide-up-leave-to{transform:translateY(20px);opacity:0}
