[x-cloak]{display:none!important}@font-face{font-family:Tamanegi;src:url(/fonts/tamanegi_kaisho_free.ttf) format("truetype");font-display:swap}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#111827;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f9fafb}h1{font-size:1.5em;line-height:1.1;margin-bottom:.5rem;color:#111827;font-weight:700}#app{box-sizing:border-box;max-width:1280px;margin:0 auto;padding:2rem;min-height:calc(100vh - 4rem);display:flex;flex-direction:column}.navbar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a;position:sticky;top:0;z-index:1000;box-sizing:border-box;height:4rem}.nav-container{max-width:1280px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;position:relative;height:4rem}.nav-brand-wrap{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.nav-brand-icon{width:3rem;height:3rem;object-fit:contain}.nav-brand{font-family:Tamanegi,sans-serif;margin:0;font-size:1.75rem;color:#111827;font-weight:600;flex-shrink:0}.nav-menu{display:flex;list-style:none;gap:.25rem;margin:0;padding:0;align-items:center;position:absolute;left:50%;transform:translate(-50%)}.nav-link{text-decoration:none;color:#6b7280;transition:all .2s;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.375rem}.nav-link:hover{color:#2563eb;background-color:#eff6ff}.nav-link.active{color:#2563eb;background-color:#dbeafe;font-weight:600}.nav-icon{font-size:1em}.nav-label{font-size:.875rem}.user-menu-btn svg{width:1.25rem;height:1.25rem;display:block;flex-shrink:0}.lightbox-close svg,.lightbox-nav svg{width:1.25rem;height:1.25rem;display:block;flex-shrink:0}.lightbox-action-btn svg,.btn-edit-card svg,.btn-search svg,.btn-reset svg,.btn-sort svg,.btn-icon svg,.page-btn svg,.btn-retry svg,.btn-download-zip svg,.preview-add-btn svg{width:1rem;height:1rem;display:block;flex-shrink:0}.source-menu-item svg{width:1.125rem;height:1.125rem;display:block;flex-shrink:0}.upload-mode-btn svg{width:3rem;height:3rem;display:block;flex-shrink:0}.btn-back svg{width:1.25rem;height:1.25rem;display:block;flex-shrink:0}.btn-filter svg{width:1.125rem;height:1.125rem;display:block;flex-shrink:0}.user-menu-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background-color:#2563eb;color:#fff;border:none;cursor:pointer;font-weight:600;font-size:.8rem;transition:background-color .2s;flex-shrink:0}.user-menu-btn:hover,.user-menu-btn.active{background-color:#1d4ed8}.user-menu-overlay{display:none;position:fixed;inset:0;z-index:999}.user-menu-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:.25rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.25rem 0;min-width:12rem;box-shadow:0 10px 15px -3px #0000001a;z-index:1000;opacity:0;transform:scale(.95) translateY(-.25rem);transition:all .1s ease-out}.user-menu-dropdown.open{display:block;opacity:1;transform:scale(1) translateY(0)}.user-menu-header{padding:.5rem 1rem;border-bottom:1px solid #f3f4f6;color:#6b7280;font-size:.75rem}.user-menu-item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;color:#dc2626;cursor:pointer;font-family:inherit;font-size:.875rem;transition:background-color .15s}.user-menu-item:hover{background-color:#fef2f2}.user-menu-item-settings{color:#374151}.user-menu-item-settings:hover{background-color:#f3f4f6}.page-container{width:100%;max-width:800px;margin:0 auto;padding:2rem 1rem;box-sizing:border-box}.login-page-wrapper{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:1.5rem;padding-bottom:18%;background:linear-gradient(-45deg,#fff0e6,#ffe4ef,#f0e6ff,#fff4e0);background-size:400% 400%;animation:bg-shift 20s ease infinite;overflow:hidden}@keyframes bg-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}body.page-login{overflow:hidden}.login-bg{position:absolute;inset:0;pointer-events:none}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.7}.login-bg-orb-1{width:500px;height:500px;background:radial-gradient(circle,#fb923c,transparent 70%);top:-120px;left:-100px;animation:orb-drift-1 12s ease-in-out infinite alternate}.login-bg-orb-2{width:420px;height:420px;background:radial-gradient(circle,#ec4899,transparent 70%);bottom:-100px;right:-80px;animation:orb-drift-2 15s ease-in-out infinite alternate}.login-bg-orb-3{width:320px;height:320px;background:radial-gradient(circle,#fbbf24,transparent 70%);top:40%;left:50%;transform:translate(-50%,-50%);animation:orb-drift-3 10s ease-in-out infinite alternate}.login-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:48px 48px}@keyframes orb-drift-1{0%{transform:translate(0) scale(1)}to{transform:translate(80px,60px) scale(1.15)}}@keyframes orb-drift-2{0%{transform:translate(0) scale(1)}to{transform:translate(-60px,-80px) scale(1.2)}}@keyframes orb-drift-3{0%{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-50%) scale(1.3)}}.login-card-wrap{position:relative;z-index:1;width:100%;max-width:26rem;padding:0 1.25rem;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.login-brand{display:flex;align-items:center;gap:.625rem;margin-bottom:1.5rem}.login-brand-icon{width:4rem;height:4rem;object-fit:contain}.login-brand-name{font-family:Tamanegi,sans-serif;font-size:3.25rem;font-weight:800;letter-spacing:-.03em;color:#1a1a1a}.login-container{width:100%;padding:2rem;background:#fff;border-radius:1rem;border:1px solid #fde8d8;box-shadow:0 8px 40px #ea580c1a,0 2px 8px #0000000f}.login-container label{color:#374151;font-size:.875rem;font-weight:500}.login-input{width:100%;padding:.875rem 1rem;font-size:1rem;border-radius:.5rem;border:1.5px solid #e5e7eb;background:#f9fafb;color:#111827;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s}.login-input::placeholder{color:#9ca3af}.login-input:focus{outline:none;border-color:#f97316;background:#fff;box-shadow:0 0 0 3px #f9731626}.login-btn{width:100%;padding:.875rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;border:none;border-radius:.5rem;box-shadow:0 4px 15px #f973164d;transition:opacity .2s,transform .1s,box-shadow .2s;cursor:pointer;font-family:inherit}.login-btn:hover:not(:disabled){opacity:.92;box-shadow:0 6px 20px #f9731680}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.form-group{display:flex;flex-direction:column;gap:.25rem;text-align:left}.form-group label{font-weight:500;color:#374151;font-size:.875rem}.form-input,.form-group input,.form-group select,.form-group textarea{padding:.5rem .75rem;border-radius:.375rem;border:1px solid #d1d5db;background-color:#fff;color:#111827;font-family:inherit;font-size:.875rem;box-shadow:0 1px 2px #0000000d;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-hint{font-size:.75rem;color:#6b7280}.btn{border-radius:.375rem;border:1px solid transparent;padding:.5rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#2563eb;color:#fff;width:100%;box-shadow:0 1px 2px #0000000d}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-secondary{background-color:#f3f4f6;color:#374151;border-color:#d1d5db}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-modal{width:auto;min-width:5rem}.error-message{padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#991b1b;font-size:.875rem}.error-message p{margin:0}.loading-message{text-align:center;padding:3rem;color:#6b7280;display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid #dbeafe;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-sm{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-sm-gray{width:1rem;height:1rem;border:2px solid #e5e7eb;border-top-color:#9ca3af;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-bar{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem 1rem 1.25rem;margin:-2rem -2rem 0}.search-bar-inner{max-width:42rem;margin:0 auto}.search-form-layout{display:flex;flex-direction:column;gap:.75rem}.search-input{flex:1;min-width:0;padding:.625rem .875rem;border-radius:.5rem;border:1px solid #d1d5db;background-color:#fff;color:#111827;font-size:.9375rem;box-shadow:0 1px 2px #0000000d;box-sizing:border-box}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:1rem;font-size:.75rem;font-weight:500}.badge-orange{background-color:#ffedd5;color:#c2410c}.search-input-row{display:flex;align-items:center;gap:.5rem}.btn-filter{flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;padding:.625rem .75rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;color:#374151;transition:background-color .15s}.btn-filter:hover{background-color:#e5e7eb}.btn-filter-active{background-color:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.search-btn-row{display:flex;gap:.5rem}.btn-search{flex:1;display:flex;align-items:center;justify-content:center;padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#2563eb;border:none;border-radius:.375rem;cursor:pointer;transition:background-color .15s;font-family:inherit}.btn-search:hover:not(:disabled){background-color:#1d4ed8}.btn-search:disabled{background-color:#93c5fd;cursor:not-allowed}.btn-reset{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;color:#6b7280;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.btn-reset:hover:not(:disabled){background-color:#e5e7eb;color:#374151}.btn-reset:disabled{opacity:.5;cursor:not-allowed}.btn-search-content{display:flex;align-items:center;gap:.5rem}.sort-dropdown-wrap{position:relative;margin-left:auto}.btn-sort{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;color:#374151;font-size:.8125rem;font-family:inherit;transition:background-color .15s}.btn-sort:hover{background-color:#e5e7eb}.sort-menu{position:absolute;right:0;top:100%;margin-top:.5rem;width:14rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;z-index:50;padding:.25rem 0}.sort-item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;color:#374151;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background-color .1s}.sort-item:hover{background-color:#f9fafb}.sort-item.active{background-color:#eff6ff;color:#1d4ed8}.filter-active-dot{position:absolute;top:.25rem;right:.25rem;width:.4rem;height:.4rem;background-color:#2563eb;border-radius:50%;display:block}.advanced-filter-panel{border:1px solid #e5e7eb;border-radius:.5rem;padding:.875rem 1rem;background:#f9fafb}.adv-filter-grid{display:flex;flex-wrap:wrap;gap:1rem 2rem}.adv-filter-group{display:flex;flex-direction:column;gap:.375rem}.adv-filter-group-wide{flex-basis:100%}.adv-date-range{display:flex;align-items:center;gap:.5rem}.adv-date-input{border:1px solid #d1d5db;border-radius:.375rem;padding:.3rem .5rem;font-size:.875rem;font-family:inherit;color:#374151;background:#fff}.adv-date-sep{font-size:.875rem;color:#6b7280}.adv-filter-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.adv-radio-group,.adv-check-group{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.adv-radio,.adv-check{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.adv-radio input,.adv-check input{accent-color:#2563eb;cursor:pointer}.sort-divider{border:none;border-top:1px solid #f3f4f6;margin:.25rem 0}.search-results-area{padding:1rem 0;max-width:80rem;margin:0 auto}.search-error{margin-bottom:1rem;padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#991b1b;font-size:.875rem}.search-error p{margin:0}.btn-retry{margin-top:.5rem;padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500}.btn-retry:hover{background-color:#1d4ed8}.results-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#6b7280;font-size:.875rem;flex-wrap:wrap}.results-count{font-weight:600;color:#111827;white-space:nowrap}.pagination{display:flex;align-items:center;justify-content:center;gap:.25rem;margin:1.5rem 0 .5rem;flex-wrap:wrap}.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:2.25rem;padding:0 .5rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;color:#374151;font-size:.875rem;font-family:inherit;cursor:pointer;transition:all .15s}.page-btn:hover:not(:disabled){border-color:#6b7280;background:#f9fafb}.page-btn:disabled{opacity:.35;cursor:default}.page-btn-active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:600}.page-btn-active:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}.pagination-inline{flex:1;justify-content:center;margin:0}.page-indicator-compact{display:none;font-size:.875rem;color:#374151;white-space:nowrap}.pagination-inline .page-btn-step{display:none}@media(max-width:540px){.page-btns-full{display:none}.page-indicator-compact{display:inline}.pagination-inline .page-btn-edge{display:none}.pagination-inline .page-btn-step{display:inline-flex}}.no-results-card{text-align:center;padding:1.5rem;max-width:28rem;margin:0 auto;background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem}.no-results-icon-wrap{color:#6b7280;margin-bottom:.75rem}.no-results-icon-wrap svg{display:inline-block}.no-results-card h3{font-size:1.125rem;font-weight:500;color:#111827;margin:0 0 .5rem}.no-results-card>p{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.results-grid{display:grid;grid-template-columns:1fr;gap:1rem}.card-image-wrap{width:100%;aspect-ratio:16 / 9;border-radius:.375rem;overflow:hidden;margin-bottom:.75rem;background-color:#f3f4f6;border:1px solid #9ca3af}.card-image{width:100%;height:100%;object-fit:contain;display:block}.card-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f9fafb}.card-image-loading{background-color:#f3f4f6}.result-card{padding:1rem;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;transition:all .2s;cursor:pointer}.result-card:hover{border-color:#93c5fd;box-shadow:0 4px 6px -1px #0000001a}.card-title-area{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem}.result-card h3{margin:0;color:#111827;font-size:.875rem;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.description{color:#6b7280;margin:.5rem 0;line-height:1.4;font-size:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f3f4f6}.card-date{font-size:.75rem;color:#9ca3af}.card-registered-by{font-size:.75rem;color:#6b7280}.card-actions{display:flex;gap:.5rem}.btn-icon{background:none;border:none;font-size:1.1em;cursor:pointer;padding:.375rem;border-radius:.375rem;transition:background-color .15s}.btn-icon:hover{background-color:#f3f4f6}.btn-delete:hover{background-color:#fef2f2}@media(min-width:640px){.results-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.results-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.results-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){#app{padding:1rem}.nav-container{padding:0 .75rem;gap:.25rem}.nav-menu{gap:.125rem}.nav-label{display:none}.nav-link{padding:.5rem}.nav-brand-icon{display:none}.nav-brand{font-size:1.5rem}.page-container{padding:1rem}.login-container{padding:1.25rem}.form-input,.form-group input,.form-group select,.form-group textarea,.search-input{padding:.625rem .75rem;font-size:16px;min-height:2.75rem}.btn{padding:.625rem 1rem;min-height:2.75rem}.search-bar{margin:-1rem -1rem 0;padding:.75rem 1rem 1rem}}.upload-mode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem;width:50%;aspect-ratio:1 / 1;padding:1rem;margin:0 auto;background-color:#fff;border:2px dashed #d1d5db;border-radius:.75rem;cursor:pointer;color:#374151;transition:all .2s;font-family:inherit}.upload-mode-btn:hover{border-color:#2563eb;background-color:#eff6ff;color:#2563eb}.upload-mode-label{font-size:1.125rem;font-weight:600}.upload-mode-sub{font-size:.75rem;color:#9ca3af}.upload-mode-btn:hover .upload-mode-sub{color:#60a5fa}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.preview-item{position:relative;border-radius:.5rem;overflow:hidden;border:1px solid #e5e7eb;aspect-ratio:85 / 54;background-color:#f3f4f6;cursor:pointer;container-type:size;display:flex;align-items:center;justify-content:center}.preview-img{max-width:100%;max-height:100%;display:block}.preview-img.preview-img-sideways{max-width:100cqh;max-height:100cqw}.preview-remove{position:absolute;top:.375rem;right:.375rem;width:2rem;height:2rem;background-color:#0000008c;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s}.preview-remove svg{width:1rem;height:1rem;display:block;flex-shrink:0}.preview-remove:hover{background-color:#dc2626d9}.preview-index{position:absolute;bottom:.25rem;left:.375rem;background-color:#00000073;color:#fff;font-size:.7rem;font-weight:600;padding:.0625rem .375rem;border-radius:.25rem}.preview-count{font-size:.875rem;color:#6b7280;text-align:right}.toggle-btn{position:relative;flex-shrink:0;width:2.75rem;height:1.5rem;border-radius:9999px;border:none;cursor:pointer;transition:background-color .2s;padding:0}.toggle-btn-off{background-color:#d1d5db}.toggle-btn-on{background-color:#2563eb}.toggle-knob{position:absolute;top:.1875rem;left:.1875rem;width:1.125rem;height:1.125rem;background:#fff;border-radius:50%;transition:transform .2s;display:block}.toggle-btn-on .toggle-knob{transform:translate(1.25rem)}.preview-has-notes{position:absolute;bottom:.25rem;right:.375rem;font-size:.8rem;line-height:1}.preview-too-big{position:absolute;top:.3rem;left:.3rem;background-color:#ef4444;color:#fff;font-size:.7rem;font-weight:700;line-height:1;padding:.2rem .4rem;border-radius:9999px;pointer-events:none}.preview-public-badge{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:none;cursor:pointer;transition:background-color .15s;position:absolute;bottom:.375rem;right:.375rem}.preview-public-badge-on{background-color:#2563eb;color:#fff}.preview-public-badge-on:hover{background-color:#1d4ed8}.preview-public-badge-off{background-color:#f97316;color:#fff}.preview-public-badge-off:hover{background-color:#2563eb}.preview-action-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.375rem;padding-bottom:.375rem}.preview-count{margin:.25rem 0 .75rem;font-size:.875rem;color:#6b7280}.bulk-public-btns{display:flex;gap:.375rem}.bulk-public-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .625rem;font-size:.75rem;font-weight:500;border-radius:.375rem;border:1px solid #d1d5db;background:#f9fafb;color:#6b7280;cursor:pointer;font-family:inherit;transition:all .15s}.bulk-public-btn:hover{border-color:#93c5fd;color:#1d4ed8;background:#eff6ff}.bulk-public-btn-active{border-color:#93c5fd;background:#dbeafe;color:#1d4ed8}.lightbox-public-row{display:flex;align-items:center;gap:.625rem;margin-top:.625rem}.register-header{text-align:center;margin-bottom:1.5rem}.register-header-compact{margin-top:-1.75rem}.upload-btn-wrap{position:fixed;bottom:0;left:0;right:0;padding:.75rem 1rem;background-color:#fefce8;border-top:1px solid #fde68a;display:flex;justify-content:center;z-index:50}.upload-btn-wrap .btn{width:100%;max-width:32rem;background-color:#059669}.upload-btn-wrap .btn:hover:not(:disabled){background-color:#047857}@media(min-height:600px){.upload-btn-wrap .btn{padding-top:.875rem;padding-bottom:.875rem;font-size:1rem}}@media(min-height:800px){.upload-btn-wrap .btn{padding-top:1.125rem;padding-bottom:1.125rem;font-size:1.125rem}}.upload-done{text-align:center;padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.upload-done-title{font-size:1.125rem;font-weight:600;color:#16a34a;margin:0}.preview-item:hover .preview-img{opacity:.85}.preview-add-btn{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;background-color:#2563eb;border:none;border-radius:9999px;cursor:pointer;color:#fff;font-size:.8rem;font-weight:500;font-family:inherit;transition:background-color .15s;white-space:nowrap}.preview-add-btn:hover{background-color:#1d4ed8}.source-pick-wrap{position:relative;display:block;width:100%}.preview-action-bar .source-pick-wrap{display:inline-flex;width:auto}.source-menu{position:absolute;top:calc(100% + .375rem);left:0;z-index:100;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 4px 12px #0000001a;min-width:9rem;overflow:hidden}.source-menu-sm{min-width:7.5rem}.source-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .875rem;background:none;border:none;cursor:pointer;font-size:.875rem;font-family:inherit;color:#374151;text-align:left;transition:background-color .1s}.source-menu-item:hover{background-color:#f3f4f6}.scanning-overlay{position:fixed;inset:0;background-color:#0009;z-index:3000;display:flex;align-items:center;justify-content:center}.scanning-dialog{background:#fff;border-radius:1rem;padding:2rem 2.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.scanning-label{font-size:.9rem;color:#374151;margin:0}.lightbox-overlay{position:fixed;inset:0;background-color:#000000e0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.lightbox-dialog{background-color:#fff;border-radius:.75rem;width:100%;max-width:48rem;height:calc(100vh - 2rem);max-height:44rem;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0006}.lightbox-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid #e5e7eb}.lightbox-header-actions{display:flex;align-items:center;gap:1rem}.lightbox-counter{font-size:.875rem;color:#6b7280}.lightbox-close{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background-color:#ef4444;border:none;border-radius:50%;cursor:pointer;color:#fff;transition:background-color .15s}.lightbox-close:hover{background-color:#dc2626}.lightbox-img-area{display:flex;align-items:center;justify-content:center;flex:1;min-height:0;background-color:#d1d5db;overflow:hidden;padding:.75rem;box-sizing:border-box;container-type:size}.lightbox-img{max-width:100cqw;max-height:100cqh;width:auto;height:auto;display:block;border:2px solid #ffffff}.lightbox-img.lightbox-img-sideways{max-width:100cqh;max-height:100cqw}@keyframes slide-from-right{0%{transform:translate(60px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slide-from-left{0%{transform:translate(-60px);opacity:0}to{transform:translate(0);opacity:1}}.lightbox-img-slide-next{animation:slide-from-right .22s ease}.lightbox-img-slide-prev{animation:slide-from-left .22s ease}.lightbox-nav-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.625rem 1rem;border-top:1px solid #e5e7eb;background-color:#fff}.lightbox-nav{width:2.25rem;height:2.25rem;background-color:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s;box-shadow:0 1px 3px #00000014}.lightbox-nav:hover:not(:disabled){background-color:#e5e7eb}.lightbox-nav:disabled{opacity:.25;cursor:default}.lightbox-action-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background-color:#374151;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .15s;box-shadow:0 1px 3px #00000040}.lightbox-action-btn:disabled{opacity:.3;cursor:default}.lightbox-action-btn:hover:not(:disabled){background-color:#1f2937}.lightbox-action-btn-active{background-color:#2563eb;color:#fff}.lightbox-action-btn-active:hover:not(:disabled){background-color:#1d4ed8}.lightbox-notes-area{padding:.875rem 1rem;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.375rem;background-color:#fff}.lightbox-notes-label{display:flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:500;color:#6b7280}.lightbox-notes-input{width:100%;padding:.5rem .75rem;border-radius:.375rem;border:1px solid #d1d5db;background-color:#f9fafb;color:#111827;font-family:inherit;font-size:.875rem;resize:vertical;box-sizing:border-box}.lightbox-notes-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.lightbox-notes-input::placeholder{color:#9ca3af}.card-lightbox-header{display:flex;justify-content:flex-end;width:100%;padding:.5rem .625rem;box-sizing:border-box}.card-lightbox-close{width:2rem;height:2rem;border-radius:50%;background-color:#ef4444;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s}.card-lightbox-close svg{width:1rem;height:1rem;display:block;flex-shrink:0}.card-lightbox-close:hover{background-color:#dc2626}.card-lightbox-dialog{position:relative;background:#fff;border-radius:1rem;width:92vw;max-width:720px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000059}.card-lightbox-img-area{flex-shrink:0;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:.75rem 1.25rem .375rem;min-height:15rem}.card-lightbox-img-area .card-image-placeholder{min-height:15rem;width:100%}.card-lightbox-img{max-width:100%;max-height:45vh;width:auto;height:auto;object-fit:contain;border:1px solid #9ca3af;border-radius:.25rem;display:block}.card-lightbox-info{padding:.5rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.375rem}.card-lightbox-name{font-size:1.2rem;font-weight:700;color:#111827}.card-lightbox-company{font-size:.95rem;color:#4b5563}.card-lightbox-meta-label{font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}.card-lightbox-notes{font-size:.875rem;color:#374151;background:#f9fafb;border-radius:.5rem;padding:.625rem .75rem;margin-top:.25rem;max-height:8rem;overflow-y:auto}.card-lightbox-notes .notes-text{white-space:pre-wrap;line-height:1.4}.card-lightbox-date{font-size:.8rem;color:#9ca3af;margin-top:.25rem}.img-viewer-overlay{position:fixed;inset:0;z-index:4000;background:#000000eb;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.img-viewer-img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none}@media(max-width:480px){.upload-mode-btn{width:80%}.preview-grid{grid-template-columns:1fr}.lightbox-dialog{height:calc(100vh - 2rem);max-height:calc(100vh - 2rem);border-radius:.75rem}.card-lightbox-dialog{width:100vw;max-width:100vw;max-height:100vh;border-radius:0}.card-lightbox-img{max-height:45vh}}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem}.settings-item-col{flex-direction:column;align-items:flex-start;gap:.375rem}.settings-item-label{display:flex;flex-direction:column;gap:.25rem}.settings-item-title{font-size:.875rem;font-weight:500;color:#111827}.settings-item-desc{font-size:.75rem;color:#6b7280}.settings-item-control{display:flex;align-items:center;gap:.625rem;flex-shrink:0}.settings-item-control .form-input{width:12rem}.settings-toggle-label{font-size:.8rem;color:#6b7280;min-width:2.5rem;text-align:right}.settings-saved-msg{text-align:center;font-size:.875rem;color:#16a34a;font-weight:500}.settings-section{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem}.settings-section-title{margin:0;font-size:1.25rem;font-weight:700;color:#111827;text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.btn-download-zip{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background-color:#374151;color:#fff;border:none;border-radius:.5rem;font-size:.8rem;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .15s}.btn-download-zip:hover:not(:disabled){background-color:#1f2937}.btn-download-zip:disabled{opacity:.5;cursor:not-allowed}.password-modal{background:#fff;border-radius:.75rem;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #00000059}.password-modal-title{font-size:1rem;font-weight:600;color:#111827;margin:0 0 1.25rem}.password-modal-fields{display:flex;flex-direction:column;gap:1rem}.password-modal-field{display:flex;flex-direction:column;gap:.375rem}.password-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem}.edit-header{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.edit-header h1,.edit-header h2{margin:0;font-size:1.25rem;text-align:center}.edit-header .btn-back{position:absolute;left:0}.btn-back{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.875rem;font-family:inherit;cursor:pointer;transition:all .15s}.btn-back:hover{background:#f9fafb;border-color:#9ca3af}.edit-image-wrap{display:flex;justify-content:center;margin-bottom:1.5rem}.edit-image{max-width:100%;max-height:16rem;object-fit:contain;border-radius:.5rem;border:1px solid #e5e7eb}.edit-form{display:flex;flex-direction:column;gap:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.375rem}.form-textarea{width:100%;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;font-family:inherit;color:#111827;background:#fff;resize:vertical;box-sizing:border-box;white-space:pre-wrap}.form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.form-error{color:#dc2626;font-size:.875rem}.edit-actions{padding-top:.5rem}.edit-actions .btn{width:100%;padding:.875rem 1rem;font-size:1rem;font-weight:600;border-radius:.5rem}@media(min-height:800px){.edit-actions .btn{padding:1.125rem 1rem;font-size:1.125rem}}.btn-edit-card{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:50%;background:#2563eb;color:#fff;cursor:pointer;transition:background-color .15s,transform .15s;margin-right:auto;flex-shrink:0}.btn-edit-card:hover{background:#1d4ed8;transform:scale(1.1)}.confirm-dialog{background:#fff;border-radius:.75rem;padding:1.5rem;width:100%;max-width:360px;box-shadow:0 20px 60px #00000059}.confirm-dialog-message{font-size:.9375rem;color:#111827;margin:0 0 1.25rem;line-height:1.5}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:.75rem}.confirm-dialog-actions .btn:focus{outline:3px solid #2563eb;outline-offset:2px}.confirm-dialog-actions .btn-danger:focus{outline-color:#dc2626}
