@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid}::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::-webkit-file-upload-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::-webkit-file-upload-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:-webkit-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:-moz-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:-webkit-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:-moz-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:-webkit-any([multiple],[size])) optgroup option{padding-inline-start:20px}:where(select:-moz-any([multiple],[size])) optgroup option{padding-inline-start:20px}:where(select:-webkit-any([multiple],[size])) optgroup option{padding-inline-start:20px}:where(select:-moz-any([multiple],[size])) optgroup option{padding-inline-start:20px}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::-webkit-file-upload-button{margin-inline-end:4px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-year-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-month-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-day-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-hour-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-minute-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-second-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-millisecond-field{padding-block-start:0;padding-block-end:0}::-webkit-datetime-edit-meridiem-field{padding-block-start:0;padding-block-end:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button{-webkit-appearance:button;-moz-appearance:button;appearance:button}input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-file-upload-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.static{position:static}.start:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){left:var(--spacing)}.start:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){left:var(--spacing)}.start:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){left:var(--spacing)}.start:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){left:var(--spacing)}.start:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){left:var(--spacing)}.start:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){right:var(--spacing)}.start:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){right:var(--spacing)}.start:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){right:var(--spacing)}.end:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){right:var(--spacing)}.end:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){right:var(--spacing)}.end:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){right:var(--spacing)}.end:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){right:var(--spacing)}.end:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){right:var(--spacing)}.end:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){left:var(--spacing)}.end:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){left:var(--spacing)}.end:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){left:var(--spacing)}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x, )var(--tw-rotate-y, )var(--tw-rotate-z, )var(--tw-skew-x, )var(--tw-skew-y, )}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}}body{color:#fff;background-image:linear-gradient(#020917,#101725);margin:0;font-family:Inter,Avenir,Helvetica,Arial,sans-serif}.content{text-align:center;flex-direction:column;justify-content:center;min-height:100vh;line-height:1.1;display:flex}.content h1{font-size:3.6rem;font-weight:700}.content p{opacity:.5;font-size:1.2rem;font-weight:400}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}body{background:#f5f7fa;min-height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.gallery-container{background:#fff;max-width:1600px;min-height:100vh;margin:0 auto;padding:0;box-shadow:0 0 40px #0000000d}.gallery-header{z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;position:sticky;top:0}.gallery-header h1{color:#111827;margin:0;font-size:1.5rem;font-weight:600}.header-actions{gap:.75rem;display:flex}.upload-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.upload-btn:hover{background:#059669}.upload-btn.uploading{opacity:.6;cursor:not-allowed}.storage-quota{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem}.storage-quota-main{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.storage-quota h2{color:#111827;margin:0;font-size:1rem;font-weight:600}.storage-quota p{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.storage-quota button{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.4rem .75rem;font-size:.8125rem}.storage-quota button:hover{background:#f9fafb;border-color:#9ca3af}.storage-quota-bar{background:#e5e7eb;border-radius:999px;width:100%;height:10px;overflow:hidden}.storage-quota-fill{border-radius:inherit;background:linear-gradient(90deg,#10b981,#34d399);height:100%;transition:width .2s}.storage-quota-footer{color:#6b7280;justify-content:space-between;gap:1rem;margin-top:.5rem;font-size:.8125rem;display:flex}.storage-quota--notice .storage-quota-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.storage-quota--notice .storage-quota-footer{color:#92400e}.storage-quota--warning .storage-quota-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.storage-quota--warning .storage-quota-footer,.storage-quota--warning p{color:#b91c1c}.upload-progress-panel{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem 2rem}.upload-progress-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.upload-progress-header h2{color:#111827;margin:0;font-size:1rem;font-weight:600}.upload-progress-header p{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.upload-progress-actions{align-items:center;gap:.75rem;display:flex}.upload-progress-value{color:#111827;font-size:1.25rem;font-weight:700}.upload-progress-close{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:999px;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.125rem;line-height:1;transition:all .2s;display:flex}.upload-progress-close:hover{color:#111827;background:#f3f4f6}.upload-task-list{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.upload-task-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:.875rem 1rem}.upload-task-meta{justify-content:space-between;gap:1rem;margin-bottom:.5rem;display:flex}.upload-task-text{flex-direction:column;gap:.25rem;min-width:0;display:flex}.upload-task-name{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.upload-task-stage{color:#6b7280;font-size:.8125rem}.upload-task-stage.error{color:#b91c1c}.upload-task-percent{color:#374151;flex-shrink:0;font-size:.875rem;font-weight:600}.progress-bar{background:#e5e7eb;border-radius:999px;width:100%;height:8px;overflow:hidden}.progress-bar-total{height:10px}.progress-bar-fill{border-radius:inherit;background:linear-gradient(90deg,#10b981,#34d399);height:100%;transition:width .2s}.progress-bar-fill.error{background:linear-gradient(90deg,#ef4444,#f87171)}.toolbar{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 2rem;display:flex}.group-toolbar{background:#fff;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:.5rem;padding:.75rem 2rem;display:flex}.group-chip{color:#374151;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;padding:.375rem .75rem;font-size:.8125rem;transition:all .2s}.group-chip:hover{color:#047857;border-color:#10b981}.group-chip.active{color:#fff;background:#10b981;border-color:#10b981}.toolbar-left{flex:1;gap:.75rem;min-width:300px;display:flex}.toolbar-right{align-items:center;gap:.75rem;display:flex}.search-box{background:#fff;border:1px solid #d1d5db;border-radius:8px;flex:1;align-items:center;gap:.5rem;max-width:400px;padding:.5rem .875rem;display:flex}.search-box svg{color:#9ca3af;flex-shrink:0}.search-box input{color:#111827;border:none;outline:none;width:100%;font-size:.875rem}.search-box input::placeholder{color:#9ca3af}.sort-select{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;outline:none;padding:.5rem .875rem;font-size:.875rem}.date-range-filter{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.date-field{color:#6b7280;align-items:center;gap:.375rem;font-size:.8125rem;display:flex}.date-field input[type=date]{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.4rem .6rem;font-size:.8125rem}.date-clear-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.4rem .7rem;font-size:.8125rem}.date-clear-btn:hover{background:#f9fafb;border-color:#9ca3af}.selected-count{color:#6b7280;font-size:.875rem;font-weight:500}.batch-delete-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.batch-delete-btn:hover{background:#dc2626}.view-toggle{background:#fff;border:1px solid #d1d5db;border-radius:8px;display:flex;overflow:hidden}.view-toggle button{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;padding:.5rem .75rem;transition:all .2s;display:flex}.view-toggle button:hover{background:#f3f4f6}.view-toggle button.active{color:#fff;background:#10b981}.view-toggle button+button{border-left:1px solid #d1d5db}.error-message{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;justify-content:space-between;align-items:center;margin:1rem 2rem;padding:1rem 1.5rem;font-size:.875rem;display:flex}.error-message button{color:#991b1b;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.25rem}.info-message{color:#1e40af;text-align:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;justify-content:center;align-items:center;width:-moz-fit-content;width:fit-content;min-width:200px;margin:1rem auto;padding:.75rem 1.25rem;font-size:.875rem;line-height:1.5;display:flex}.hidden{display:none}.empty-state{text-align:center;color:#9ca3af;padding:6rem 2rem}.empty-icon{opacity:.5;width:4rem;height:4rem;margin:0 auto 1rem}.empty-state p{margin:0;font-size:1rem}.gallery-grid{background:#e5e7eb;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;padding:2rem;display:grid}.gallery-grid .gallery-item{aspect-ratio:1;cursor:pointer;background:#fff;transition:all .2s;position:relative;overflow:hidden}.gallery-grid .gallery-item:hover{z-index:10;transform:scale(.98)}.gallery-grid .gallery-item.selected{outline-offset:-3px;outline:3px solid #10b981}.gallery-item img{object-fit:cover;width:100%;height:100%}.image-preview-btn{cursor:pointer;background:0 0;border:none;width:100%;height:100%;padding:0}.gallery-list{padding:2rem}.gallery-list .gallery-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:1rem;margin-bottom:.5rem;padding:.75rem;transition:all .2s;display:flex}.gallery-list .gallery-item:hover{background:#f9fafb;border-color:#d1d5db}.gallery-list .gallery-item.selected{background:#ecfdf5;border-color:#10b981}.gallery-list .gallery-item img{object-fit:cover;border-radius:6px;flex-shrink:0;width:60px;height:60px}.item-checkbox{z-index:20;position:absolute;top:.5rem;left:.5rem}.item-checkbox input[type=checkbox]{cursor:pointer;accent-color:#10b981;width:18px;height:18px}.item-info{flex:1;align-items:center;gap:1rem;min-width:0;display:flex}.item-name{color:#374151;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;overflow:hidden}.item-size{color:#9ca3af;flex-shrink:0;font-size:.75rem}.gallery-grid .item-info{opacity:0;background:linear-gradient(#0000,#000000b3);padding:2rem .75rem .75rem;transition:opacity .2s;position:absolute;bottom:0;left:0;right:0}.gallery-grid .item-name{color:#fff;font-size:.75rem}.gallery-grid .gallery-item:hover .item-info{opacity:1}.delete-btn{color:#ef4444;cursor:pointer;opacity:0;z-index:20;background:#fff;border:none;border-radius:6px;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.25rem;line-height:1;transition:all .2s;display:flex;position:absolute;top:.5rem;right:.5rem;box-shadow:0 2px 8px #0000001a}.delete-btn:hover{color:#fff;background:#ef4444}.share-btn{color:#0f766e;cursor:pointer;opacity:0;z-index:20;background:#fff;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:2.6rem;height:2rem;padding:0 .45rem;font-size:.75rem;line-height:1;transition:all .2s;display:flex;position:absolute;top:.5rem;right:3rem;box-shadow:0 2px 8px #0000001a}.share-btn:hover{color:#fff;background:#0f766e}.gallery-item:hover .delete-btn,.gallery-item:hover .share-btn{opacity:1}.gallery-list .delete-btn{opacity:1;margin-left:.5rem;position:static}.gallery-list .share-btn{opacity:1;margin-left:auto;position:static}.load-more-wrap{justify-content:center;padding:0 2rem 2rem;display:flex}.load-more-btn{color:#111827;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;min-width:140px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s}.load-more-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox{z-index:1000;background:#000000e6;flex-direction:column;justify-content:center;align-items:center;padding:2rem;animation:.2s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.lightbox-backdrop{cursor:pointer;background:0 0;border:none;padding:0;position:absolute;top:0;bottom:0;left:0;right:0}.lightbox img{z-index:1;object-fit:contain;border-radius:8px;max-width:90%;max-height:80vh;position:relative;box-shadow:0 20px 60px #00000080}.close-btn{z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1.5rem;line-height:1;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.close-btn:hover{background:#fff3}.lightbox-loading{z-index:1;color:#fff;background:#ffffff14;border-radius:8px;justify-content:center;align-items:center;min-width:280px;min-height:240px;font-size:1rem;display:flex;position:relative;box-shadow:0 20px 60px #0000004d}.image-name{z-index:1;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;border-radius:6px;margin-top:1rem;padding:.5rem 1rem;font-size:.875rem;font-weight:400;position:relative}.home-actions{align-items:center;gap:.5rem;display:flex}.mnemonic-trigger-btn{color:#047857;cursor:pointer;background:#ecfdf5;border:1px solid #10b981;border-radius:8px;padding:.45rem .85rem;font-size:.875rem}.mnemonic-trigger-btn:hover{background:#d1fae5}.mnemonic-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0f172a8c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.mnemonic-dialog{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:min(760px,100%);padding:1.25rem;box-shadow:0 18px 48px #02061747}.mnemonic-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.mnemonic-header h2{color:#0f172a;margin:0;font-size:1.125rem}.mnemonic-close-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:999px;width:2rem;height:2rem;font-size:1.2rem;line-height:1}.mnemonic-close-btn:hover{background:#e5e7eb}.mnemonic-tip{color:#374151;margin:.9rem 0 0;font-size:.875rem}.mnemonic-loading,.mnemonic-error{color:#374151;background:#f9fafb;border-radius:12px;margin-top:1rem;padding:1rem}.mnemonic-error{color:#b91c1c;background:#fef2f2}.mnemonic-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;margin-top:1rem;display:grid}.mnemonic-item{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:.5rem;padding:.6rem .7rem;display:flex}.mnemonic-index{color:#6b7280;width:1.5rem;font-size:.8125rem}.mnemonic-word{color:#111827;font-size:.875rem;font-weight:600}.mnemonic-footer{justify-content:flex-end;gap:.65rem;margin-top:1rem;display:flex}.mnemonic-copy-btn,.mnemonic-done-btn{color:#111827;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.5rem .9rem;font-size:.875rem}.mnemonic-copy-btn:hover:not(:disabled),.mnemonic-done-btn:hover{background:#f9fafb}.mnemonic-copy-btn:disabled{opacity:.6;cursor:not-allowed}.mnemonic-done-btn{color:#fff;background:#10b981;border-color:#10b981}.mnemonic-done-btn:hover{background:#059669}@media (max-width:900px){.mnemonic-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.mnemonic-grid{grid-template-columns:1fr}}.auth-container{background:#f5f5f5;justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-form{color:#333;background:#fff;border-radius:8px;width:100%;max-width:400px;padding:2rem;box-shadow:0 2px 10px #0000001a}.auth-form h2{text-align:center;color:#333;margin:0 0 1.5rem}.auth-form input{border:1px solid #ddd;border-radius:4px;width:100%;margin-bottom:1rem;padding:.75rem;font-size:1rem}.auth-form button[type=submit]{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:4px;width:100%;padding:.75rem;font-size:1rem}.auth-form button[type=submit]:hover{background:#0056b3}.auth-form button[type=submit]:disabled{cursor:not-allowed;background:#ccc}.error{color:#c33;background:#fee;border-radius:4px;margin-bottom:1rem;padding:.75rem;font-size:.9rem}.switch-link{text-align:center;margin-top:1rem;font-size:.9rem}.switch-link button{color:#007bff;cursor:pointer;background:0 0;border:none;text-decoration:underline}.share-page{background:#f3f4f6;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.share-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;width:min(920px,100%);padding:1.25rem;box-shadow:0 14px 32px #00000014}.share-card h1{color:#111827;margin:0;font-size:1.25rem}.share-desc{color:#6b7280;margin:.45rem 0 1rem;font-size:.875rem}.share-meta{flex-direction:column;gap:.75rem;display:flex}.share-meta-row{flex-direction:column;gap:.35rem;display:flex}.share-meta-row span{color:#4b5563;font-size:.8125rem}.share-meta-row code{color:#111827;word-break:break-all;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.55rem .65rem;font-size:.8125rem}.share-actions{margin-top:1rem}.share-actions a{color:#0f766e;font-size:.875rem;text-decoration:none}.share-actions a:hover{text-decoration:underline}.share-loading,.share-error{border-radius:8px;margin-top:.9rem;padding:.65rem .75rem;font-size:.875rem}.share-loading{color:#0c4a6e;background:#f0f9ff;border:1px solid #bae6fd}.share-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.share-preview{background:#111827;border:1px solid #e5e7eb;border-radius:10px;margin-top:1rem;overflow:hidden}.share-preview img{object-fit:contain;width:100%;max-height:65vh;display:block}.share-footer{margin-top:1rem}.share-footer a{color:#2563eb;font-size:.875rem;text-decoration:none}.share-footer a:hover{text-decoration:underline}