:root{--width-max: 1600px;--width-ultrawide: 1900px;--sidebar-width: 320px;--sidebar-width-wide: 330px;--radius-lg: 12px;--radius-xl: 18px;--sidebar-offset: 80px;--control-radius: var(--radius-lg);--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--transition-fast: .2s ease-out;--transition-slower: .35s ease-out;--transition-slowest: .5s ease-out;--bg: #0c0b0a;--bg-black: #030200;--bg-alt: #14120e;--bg-card: #1f1b14;--bg-radial-start: #2b2416;--bg-header-end: #211c14;--bg-tooltip: rgba(20, 15, 10, .96);--text: #f5f4f2;--text-white: #ffffff;--text-light: #e6e3de;--text-sidebar: #f5f2eb;--muted: #c9c2b0;--accent: #ffb703;--accent-soft: rgba(255, 183, 3, .35);--accent-muted: #b38000;--accent-bright: #ffce47;--focus-ring: rgba(255, 183, 3, .6);--border: #423822;--border-card: rgba(255, 255, 255, .05);--border-sidebar: rgba(255, 255, 255, .07);--border-code: #2e2a22;--shadow-soft: 0 10px 30px rgba(20, 15, 0, .7);--shadow-header: 0 8px 20px rgba(15, 10, 0, .6);--shadow-tooltip: 0 12px 30px rgba(25, 20, 5, .85);--card: var(--bg-card);--panel: color-mix(in srgb, var(--bg-card) 86%, var(--bg-black) 14%);--primary: var(--accent);--primary-dark: var(--accent-muted);--text-muted: var(--muted);--text-strong: var(--text);--text-dim: var(--muted);--accent-mid: color-mix(in srgb, var(--accent) 55%, var(--bg-card) 45%);--accent-deep: color-mix(in srgb, var(--accent) 38%, var(--bg-card) 62%);--accent-border: color-mix(in srgb, var(--accent-bright) 55%, var(--border) 45%);--accent-ink: color-mix(in srgb, var(--bg-black) 82%, var(--accent) 18%);--danger: color-mix(in srgb, var(--error) 58%, var(--accent) 42%);--success: #8fe388;--error: #ff8b82;--warning: var(--accent-bright);--overlay: color-mix(in srgb, var(--bg-black) 90%, transparent);--header-height: 64px;--control-height: 42px;--accent-alpha-02: color-mix(in srgb, var(--accent) 2%, transparent);--accent-alpha-04: color-mix(in srgb, var(--accent) 4%, transparent);--accent-alpha-05: color-mix(in srgb, var(--accent) 5%, transparent);--accent-alpha-06: color-mix(in srgb, var(--accent) 6%, transparent);--accent-alpha-08: color-mix(in srgb, var(--accent) 8%, transparent);--accent-alpha-10: color-mix(in srgb, var(--accent) 10%, transparent);--accent-alpha-12: color-mix(in srgb, var(--accent) 12%, transparent);--accent-alpha-13: color-mix(in srgb, var(--accent) 13%, transparent);--accent-alpha-14: color-mix(in srgb, var(--accent) 14%, transparent);--accent-alpha-16: color-mix(in srgb, var(--accent) 16%, transparent);--accent-alpha-18: color-mix(in srgb, var(--accent) 18%, transparent);--accent-alpha-22: color-mix(in srgb, var(--accent) 22%, transparent);--accent-alpha-25: color-mix(in srgb, var(--accent) 25%, transparent);--accent-alpha-28: color-mix(in srgb, var(--accent) 28%, transparent);--accent-alpha-30: color-mix(in srgb, var(--accent) 30%, transparent);--accent-alpha-35: color-mix(in srgb, var(--accent) 35%, transparent);--accent-alpha-45: color-mix(in srgb, var(--accent) 45%, transparent);--accent-bright-alpha-35: color-mix(in srgb, var(--accent-bright) 35%, transparent);--accent-bright-alpha-45: color-mix(in srgb, var(--accent-bright) 45%, transparent);--success-alpha-10: color-mix(in srgb, var(--success) 10%, transparent);--success-alpha-28: color-mix(in srgb, var(--success) 28%, transparent);--muted-alpha-28: color-mix(in srgb, var(--muted) 28%, transparent);--white-alpha-05: color-mix(in srgb, white 5%, transparent);--white-alpha-07: color-mix(in srgb, white 7%, transparent);--white-alpha-14: color-mix(in srgb, white 14%, transparent);--white-alpha-18: color-mix(in srgb, white 18%, transparent);--white-alpha-20: color-mix(in srgb, white 20%, transparent);--white-alpha-55: color-mix(in srgb, white 55%, transparent);--white-alpha-72: color-mix(in srgb, white 72%, transparent);--black-alpha-16: color-mix(in srgb, black 16%, transparent);--black-alpha-22: color-mix(in srgb, black 22%, transparent);--black-alpha-38: color-mix(in srgb, black 38%, transparent);--black-alpha-55: color-mix(in srgb, black 55%, transparent);--accent-ink-alpha-70: color-mix(in srgb, var(--accent-ink) 70%, transparent);--accent-ink-alpha-72: color-mix(in srgb, var(--accent-ink) 72%, transparent);--accent-ink-alpha-78: color-mix(in srgb, var(--accent-ink) 78%, transparent);--accent-ink-alpha-84: color-mix(in srgb, var(--accent-ink) 84%, transparent);--accent-ink-alpha-85: color-mix(in srgb, var(--accent-ink) 85%, transparent);--accent-ink-alpha-88: color-mix(in srgb, var(--accent-ink) 88%, transparent);--accent-ink-alpha-90: color-mix(in srgb, var(--accent-ink) 90%, transparent);--footer-bg-start: color-mix(in srgb, var(--bg) 96%, transparent);--footer-bg-end: color-mix(in srgb, var(--bg-header-end) 96%, transparent);--footer-shadow: 0 -8px 20px color-mix(in srgb, var(--bg-black) 45%, transparent);--login-error: color-mix(in srgb, var(--error) 85%, white 15%);--btn-view-bg: var(--accent-alpha-12);--btn-view-border: var(--accent-alpha-45);--btn-view-hover-bg: var(--accent-alpha-22);--btn-save-bg: color-mix(in srgb, var(--accent) 68%, var(--bg-card) 32%);--btn-save-border: color-mix(in srgb, var(--accent-bright) 72%, var(--border) 28%);--btn-save-hover-bg: color-mix(in srgb, var(--accent) 78%, var(--bg-card) 22%);--btn-save-danger-bg: var(--danger);--btn-save-danger-hover-bg: color-mix(in srgb, var(--danger) 80%, var(--accent) 20%);--btn-save-disabled-bg: var(--accent-alpha-10);--btn-save-disabled-border: var(--accent-alpha-28);--btn-save-disabled-text: var(--white-alpha-72);--select-btn-bg: color-mix(in srgb, var(--accent-muted) 72%, var(--bg-card) 28%);--select-btn-border: color-mix(in srgb, var(--accent) 48%, var(--border) 52%);--select-btn-active-bg: var(--accent-alpha-16);--select-btn-active-border: var(--accent-alpha-45);--sticky-header-bg-start: color-mix(in srgb, var(--bg-black) 95%, transparent);--sticky-header-bg-end: color-mix(in srgb, var(--bg-black) 78%, transparent);--header-toggle-bg: var(--accent-alpha-08);--header-toggle-hover-bg: var(--accent-alpha-18);--surface-gradient-start: color-mix(in srgb, var(--bg-radial-start) 78%, var(--bg-card) 22%);--surface-gradient-end: color-mix(in srgb, var(--bg-card) 72%, var(--bg-black) 28%);--surface-action-bg: var(--accent-ink-alpha-84);--surface-badge-bg: var(--accent-ink-alpha-88);--surface-subtle-bg: var(--accent-alpha-06);--surface-card-inner: color-mix(in srgb, var(--bg-card) 82%, var(--bg-black) 18%);--surface-gradient-soft-start: var(--accent-alpha-08);--surface-gradient-soft-end: var(--accent-alpha-02);--gallery-tone-1: color-mix(in srgb, var(--bg-card) 82%, var(--accent-deep) 18%);--gallery-tone-2: color-mix(in srgb, var(--bg-card) 76%, var(--accent-deep) 24%);--gallery-tone-3: color-mix(in srgb, var(--bg-card) 70%, var(--accent-deep) 30%);--gallery-tone-4: color-mix(in srgb, var(--bg-card) 86%, var(--accent-deep) 14%);--gallery-placeholder-start: var(--accent-alpha-06);--gallery-placeholder-mid: var(--accent-alpha-02);--gallery-placeholder-end: var(--accent-alpha-08);--select-checkbox-bg: var(--accent-ink-alpha-72);--delete-btn-bg: var(--accent-ink-alpha-78);--delete-btn-border: color-mix(in srgb, var(--accent) 56%, var(--border) 44%);--delete-btn-hover-bg: color-mix(in srgb, var(--accent) 70%, var(--bg-card) 30%);--gallery-dim-label-bg: var(--black-alpha-55);--gallery-album-label-bg: color-mix(in srgb, var(--accent-ink) 72%, transparent);--tag-widget-shadow-color: var(--black-alpha-22);--tag-cloud-btn-hover-bg: var(--accent-alpha-12);--settings-tabs-bg: var(--accent-alpha-05);--settings-tab-hover-bg: var(--accent-alpha-08);--settings-tab-active-shadow: 0 0 0 1px var(--accent-alpha-35);--cloud-tag-hover-bg: color-mix(in srgb, var(--accent) 44%, var(--bg-card) 56%);--cloud-tag-selected-shadow: 0 0 0 1px var(--accent-alpha-45), 0 0 18px var(--accent-alpha-18);--album-access-status-border: var(--accent-alpha-25);--album-access-status-bg: var(--accent-alpha-08);--cloud-delete-border: var(--white-alpha-20);--cloud-delete-bg: var(--black-alpha-16);--cloud-delete-hover-bg: var(--white-alpha-18);--close-lightbox-bg: var(--accent-ink-alpha-70);--lb-refresh-border: var(--accent-alpha-14);--lb-refresh-bg: var(--accent-alpha-08);--lb-refresh-shadow: inset 0 0 0 1px var(--accent-alpha-04);--lb-refresh-hover-border: var(--accent-bright-alpha-35);--lb-refresh-hover-bg: var(--accent-alpha-16);--preview-status: color-mix(in srgb, var(--muted) 84%, white 16%);--toggle-track-bg: color-mix(in srgb, var(--muted) 52%, var(--accent-ink) 48%);--toggle-track-border: color-mix(in srgb, var(--muted) 68%, var(--accent-ink) 32%);--toggle-track-shadow: inset 0 1px 2px var(--black-alpha-38), 0 1px 0 var(--white-alpha-05);--toggle-thumb-bg-start: color-mix(in srgb, white 96%, var(--accent-bright) 4%);--toggle-thumb-bg-end: color-mix(in srgb, white 70%, var(--accent-bright) 30%);--toggle-thumb-shadow: 0 3px 8px var(--black-alpha-38), inset 0 1px 0 var(--white-alpha-55);--toggle-track-hover-bg: color-mix(in srgb, var(--muted) 64%, var(--accent-ink) 36%);--toggle-track-hover-border: color-mix(in srgb, var(--muted) 80%, var(--accent-ink) 20%);--toggle-focus-shadow: inset 0 1px 2px var(--black-alpha-38), 0 0 0 1px var(--focus-ring), 0 0 0 4px var(--accent-alpha-16);--toggle-on-bg-start: color-mix(in srgb, var(--accent) 72%, var(--bg-card) 28%);--toggle-on-bg-end: color-mix(in srgb, var(--accent-muted) 78%, var(--bg-card) 22%);--toggle-on-border: color-mix(in srgb, var(--accent-bright) 72%, var(--border) 28%);--toggle-on-shadow: inset 0 1px 2px color-mix(in srgb, var(--accent-ink) 42%, transparent), 0 0 0 1px var(--accent-alpha-12);--toggle-thumb-on-bg-start: color-mix(in srgb, white 95%, var(--accent-bright) 5%);--toggle-thumb-on-bg-end: color-mix(in srgb, white 52%, var(--accent-bright) 48%);--toggle-note-on: color-mix(in srgb, var(--accent-bright) 88%, white 12%);--admin-panel-bg: var(--accent-alpha-04);--admin-row-bg: var(--accent-alpha-04);--admin-pill-border: var(--accent-alpha-30);--admin-pill-bg: var(--accent-alpha-08);--admin-pill-highlight-border: var(--accent-bright-alpha-45);--admin-pill-guest-border: var(--muted-alpha-28);--admin-pill-disabled-border: var(--white-alpha-14);--dropzone-bg: var(--accent-alpha-04);--dropzone-hover-bg: var(--accent-alpha-13);--pending-item-bg: color-mix(in srgb, var(--bg-card) 82%, var(--bg-black) 18%);--pending-control-bg: var(--accent-ink-alpha-90);--progress-track-bg: color-mix(in srgb, var(--bg-card) 70%, var(--bg-black) 30%);--bulk-toolbar-shadow: 0 -5px 20px color-mix(in srgb, var(--accent-ink) 65%, transparent);--toast-bg: color-mix(in srgb, var(--bg-card) 88%, var(--bg-black) 12%);--toast-border: color-mix(in srgb, var(--border) 70%, var(--accent-ink) 30%);--toast-success-color: color-mix(in srgb, var(--accent-bright) 92%, white 8%);--toast-success-bg-start: color-mix(in srgb, var(--accent-bright) 24%, var(--bg-black) 76%);--toast-success-bg-end: color-mix(in srgb, var(--accent-bright) 10%, var(--bg-black) 90%);--toast-success-shadow: 0 12px 30px color-mix(in srgb, var(--accent-bright) 44%, transparent);--toast-warning-color: color-mix(in srgb, var(--accent) 88%, white 12%);--toast-warning-bg-start: color-mix(in srgb, var(--accent) 28%, var(--bg-black) 72%);--toast-warning-bg-end: color-mix(in srgb, var(--accent) 12%, var(--bg-black) 88%);--toast-warning-shadow: 0 12px 30px color-mix(in srgb, var(--accent) 46%, transparent);--toast-error-color: color-mix(in srgb, var(--danger) 82%, white 18%);--toast-error-bg-start: color-mix(in srgb, var(--danger) 30%, var(--bg-black) 70%);--toast-error-bg-end: color-mix(in srgb, var(--danger) 14%, var(--bg-black) 86%);--toast-error-shadow: 0 12px 30px color-mix(in srgb, var(--danger) 44%, transparent)}@media(min-width:2000px){:root{--width-max: var(--width-ultrawide);--sidebar-width: var(--sidebar-width-wide)}}*,*:before,*:after{box-sizing:border-box;scroll-padding-top:160px}html{-webkit-text-size-adjust:100%;scrollbar-width:thin;scrollbar-color:var(--muted) transparent;width:100vw;overflow-x:hidden}html,body{height:100%;overflow-x:hidden}[x-cloak]{display:none!important}body{margin:0;min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top,var(--bg-radial-start) 0,var(--bg) 45%,var(--bg-black) 100%);background-attachment:fixed;background-repeat:no-repeat;background-size:cover;background-color:var(--bg-black);color:var(--text);font-family:var(--font-sans);line-height:1.6;padding-top:var(--header-height)}.app-body:not(.auth-on){padding-top:0;overflow:hidden;height:100dvh;overscroll-behavior:none}.app-body:not(.auth-on) main,.app-body:not(.auth-on) .login-screen{overflow:hidden}main{width:100%;max-width:var(--width-max);margin:0 auto;padding:1rem 1.5rem 1.5rem;transition:max-width var(--transition-slower);flex:1;min-width:0}.app-footer{width:100%;margin-top:auto;position:sticky;bottom:0;z-index:900;background:linear-gradient(90deg,var(--footer-bg-start),var(--footer-bg-end));border-top:1px solid var(--border);box-shadow:var(--footer-shadow);backdrop-filter:blur(10px)}.app-footer-inner{width:100%;max-width:var(--width-max);margin:0 auto;padding:.5rem 1.5rem;display:flex;align-items:center;justify-content:center}.app-footer-link{color:var(--muted);text-decoration:none;letter-spacing:.08em;font-size:.78rem;font-weight:600;transition:color var(--transition-fast)}.app-footer-link:hover{color:var(--accent-bright)}.app-nav{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:linear-gradient(90deg,var(--bg),var(--bg-header-end));border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;z-index:1000;box-shadow:var(--shadow-header)}.nav-brand{display:inline-flex;align-items:center;font-weight:700;font-size:.95rem;color:var(--primary);letter-spacing:.08em;text-decoration:none}.nav-brand:hover{color:var(--accent-bright)}.nav-auth-actions{display:flex;align-items:center;gap:.75rem;min-width:0}.nav-links{display:flex;gap:1rem;align-items:center}.nav-mobile-actions{display:flex;align-items:center;gap:.5rem;flex:0 0 auto}.nav-menu-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--text-muted)}.nav-menu-toggle:hover,.nav-menu-toggle.active{color:var(--text);border-color:var(--border);background:color-mix(in srgb,var(--bg-card) 82%,transparent)}.nav-btn{background:transparent;color:var(--text-muted);border:none;font-size:.85rem;cursor:pointer;padding:0;height:32px;display:inline-flex;align-items:center;border-radius:0;transition:color var(--transition-fast);font-weight:600;text-transform:uppercase;letter-spacing:.08em;position:relative}.nav-btn:after{content:"";position:absolute;left:0;right:0;bottom:2px;height:2px;width:100%;background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform var(--transition-fast)}.nav-btn:hover,.nav-btn.active{color:var(--text)}.nav-btn:hover:after,.nav-btn.active:after{transform:scaleX(1)}button{cursor:pointer;border:none;font-family:inherit;transition:all var(--transition-fast)}select,input[type=text],input[type=password],input[type=number],input[type=date],input[type=search]{background:var(--card);color:var(--text);border:1px solid var(--border);padding:10px 14px;min-height:var(--control-height);border-radius:var(--control-radius);font-size:.9rem;outline:none;transition:border-color .2s}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.25rem}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:1.25rem;display:flex;flex-direction:column;gap:.65rem}.login-title{margin:0;color:var(--text);font-size:1.25rem;letter-spacing:.03em}.login-subtitle{margin:0 0 .5rem;color:var(--muted);font-size:.9rem}.login-submit{margin-top:.5rem}.login-error{margin:.35rem 0 0;color:var(--login-error);font-size:.85rem}@media(max-width:768px){.app-body:not(.auth-on) main{height:100dvh;padding:.35rem .75rem .75rem}.app-body:not(.auth-on) .login-screen{min-height:calc(100dvh - var(--header-height));margin-top:var(--header-height);align-items:flex-start;padding:.35rem 0 .75rem}}select:focus,input:focus{border-color:var(--primary);box-shadow:0 0 0 1px var(--focus-ring)}select:disabled{opacity:.5;cursor:not-allowed}.btn-view,.btn-save,.select-btn{padding:10px 20px;border-radius:999px;font-weight:600;font-size:.9rem;transition:filter .2s,background-color .2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;line-height:1}.btn-view{background:var(--btn-view-bg);color:var(--text-white);border:1px solid var(--btn-view-border)}.btn-view:hover{background:var(--btn-view-hover-bg);color:var(--text-white);border-color:var(--accent)}.btn-view:disabled,.select-btn:disabled{opacity:.55;cursor:not-allowed;filter:none}.btn-save{background:var(--btn-save-bg);color:var(--text-white);border:1px solid var(--btn-save-border)}.btn-save.danger{background:var(--btn-save-danger-bg);color:var(--text-white);border-color:var(--accent-border)}.btn-save:hover{filter:none;background:var(--btn-save-hover-bg);color:var(--text-white);border-color:var(--accent-bright)}.btn-save.danger:hover{background:var(--btn-save-danger-hover-bg);color:var(--text-white);border-color:var(--accent-bright)}.btn-save:disabled{opacity:.6;cursor:not-allowed;filter:none;background:var(--btn-save-disabled-bg);border-color:var(--btn-save-disabled-border);color:var(--btn-save-disabled-text)}.select-btn{background:var(--select-btn-bg);color:var(--text-white);border:1px solid var(--select-btn-border);margin-right:10px}.select-btn.active{background:var(--select-btn-active-bg);border:1px solid var(--select-btn-active-border);color:var(--text-white)}.btn-link{background:transparent;color:var(--text-muted);text-decoration:underline;font-size:.9rem}.btn-link:hover{color:var(--primary)}.btn-block{width:100%;display:flex;margin-bottom:6px}.btn-icon-clear{background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:5px;transition:color .2s}.btn-icon-clear:hover{color:var(--primary)}.nav-settings-btn{padding:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:is(.gallery-item-name-edit,.breadcrumb-download-btn,.lb-id-refresh){display:inline-flex;align-items:center;justify-content:center;border-radius:999px;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.text-muted{color:var(--text-muted)}.view-section{display:none;padding:0}.view-section.active{display:block;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.header-container{display:flex;justify-content:space-between;align-items:flex-start;max-width:var(--width-max);margin:0 auto 20px;padding:10px;flex-wrap:nowrap;gap:12px}.sticky-header{position:sticky;top:0;background:linear-gradient(180deg,var(--sticky-header-bg-start),var(--sticky-header-bg-end));border-radius:var(--radius-lg);z-index:100;padding:10px;border-bottom:1px solid var(--border);backdrop-filter:blur(6px)}.header-controls{display:flex;gap:15px;align-items:center;flex-grow:1;min-width:0;flex-wrap:wrap;order:1}.header-controls.is-disabled,.tag-widget.is-disabled,.tag-filter-control.is-disabled{opacity:.55;pointer-events:none}.header-controls .tag-widget{flex-grow:1;min-width:200px}.tag-filter-control{position:relative;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.tag-filter-btn{position:relative;padding:0}.tag-filter-btn:disabled{opacity:.6}.tag-filter-count{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:.68rem;font-weight:700;line-height:18px;text-align:center;box-shadow:0 0 0 2px var(--bg-black)}.gallery-search-control{position:relative;display:flex;align-items:center;min-width:0;flex:1 1 260px}.gallery-filter-menu{position:relative;flex:0 1 260px;min-width:min(240px,100%)}.header-controls>select{flex:0 1 150px;min-width:120px}.gallery-filter-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:var(--control-height);padding:10px 14px;border-radius:var(--control-radius);border:1px solid var(--border);background:var(--bg-card);color:var(--text);font:inherit;text-align:left;line-height:1.3;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.gallery-filter-toggle:hover,.gallery-filter-toggle.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha-16)}.gallery-filter-toggle:disabled{cursor:default;opacity:.65;box-shadow:none}.gallery-filter-panel{position:absolute;top:calc(100% + 8px);left:0;z-index:30;width:min(320px,calc(100vw - 32px));max-height:min(420px,70vh);overflow:auto;padding:12px;border-radius:18px;border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px}.gallery-filter-section{display:flex;flex-direction:column;gap:8px}.gallery-filter-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.gallery-filter-section-title{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.gallery-filter-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;background:color-mix(in srgb,var(--bg-card) 82%,transparent);color:var(--text);cursor:pointer}.gallery-filter-option:hover{background:color-mix(in srgb,var(--accent-alpha-16) 55%,var(--bg-card) 45%)}.gallery-filter-option.is-disabled{opacity:.5;cursor:default}.gallery-filter-option input{margin:0}.gallery-search-input{width:100%;min-height:var(--control-height);padding:10px 38px 10px 14px;border-radius:var(--control-radius);border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:.92rem;appearance:textfield}.gallery-search-input::placeholder{color:var(--text-muted)}.gallery-search-input::-webkit-search-decoration,.gallery-search-input::-webkit-search-cancel-button,.gallery-search-input::-webkit-search-results-button,.gallery-search-input::-webkit-search-results-decoration{-webkit-appearance:none;appearance:none;display:none}.gallery-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha-16)}.gallery-search-clear{position:absolute;right:6px;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:0;border-radius:999px;background:transparent;color:var(--text-muted);font-size:1.05rem;line-height:1;cursor:pointer}.gallery-search-clear:hover,.gallery-search-clear:focus-visible{color:var(--text);background:var(--accent-alpha-10);outline:none}.header-primary{display:flex;align-items:center;justify-content:flex-end;gap:10px;width:auto;min-width:0;margin-left:0;order:2}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:0}.header-action-btn{width:42px;height:42px;padding:0;margin-right:0;border-radius:14px;flex:0 0 auto}.header-action-btn svg{flex:0 0 auto}.header-drawer-toggle{display:none;padding:9px 14px;border-radius:999px;border:1px solid var(--border);background:var(--header-toggle-bg);color:var(--text);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.header-drawer-toggle:hover{border-color:var(--accent);background:var(--header-toggle-hover-bg)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:15px;max-width:var(--width-max);margin:0 auto;padding:0 10px}.gallery-item{background:var(--card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast);cursor:pointer;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;content-visibility:auto;contain-intrinsic-size:240px 214px}.gallery-item.is-reorderable{cursor:grab}.gallery-item.is-order-dragging{opacity:.55;transform:scale(.985)}.gallery-item.is-order-drop-target .gallery-thumb{box-shadow:inset 0 0 0 2px var(--accent)}.gallery-thumb{position:relative;width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;overflow:hidden}.gallery-item-footer{padding:10px 12px 12px;border-top:1px solid var(--border-soft, rgba(255, 255, 255, .06));background:var(--card)}.media-name-scroll{display:block;width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;white-space:nowrap;scrollbar-width:thin;scrollbar-color:var(--primary) transparent}.gallery-item-name{color:var(--text);font-size:.82rem;font-weight:600;line-height:1.35;user-select:text}.gallery-item-name-row{display:flex;align-items:center;gap:8px;min-width:0}.gallery-item-name-row .gallery-item-name{flex:1 1 auto;min-width:0}.gallery-item-name-edit{flex:0 0 auto;width:28px;height:28px;border:1px solid var(--accent-alpha-25);background:var(--accent-alpha-08);color:var(--accent-bright)}.gallery-item-name-edit:hover:not(:disabled),.gallery-item-name-edit:focus-visible:not(:disabled){background:var(--delete-btn-hover-bg);border-color:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}.gallery-item-name-edit:disabled{opacity:.5;cursor:not-allowed}.gallery-breadcrumbs{max-width:var(--width-max);margin:0 auto 16px;padding:0 10px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.breadcrumb-root,.breadcrumb-current,.breadcrumb-link,.breadcrumb-separator{color:var(--text);font-size:.88rem;font-weight:700;letter-spacing:.04em}.breadcrumb-trail{display:inline-flex;align-items:center;gap:8px;min-width:0}.breadcrumb-root.active,.breadcrumb-current{color:var(--text)}.breadcrumb-link{color:var(--muted);text-decoration:none;position:relative;display:inline-block;padding-bottom:2px}.breadcrumb-link:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--accent-bright);transform:scaleX(0);transform-origin:left center;transition:transform var(--transition-fast)}.breadcrumb-link:hover{color:var(--accent-bright)}.breadcrumb-link:hover:after{transform:scaleX(1)}.breadcrumb-separator{color:var(--muted)}.breadcrumb-download-btn{margin-left:auto;width:34px;height:34px;border:1px solid var(--accent-alpha-35);background:var(--surface-action-bg);color:var(--accent-bright)}.breadcrumb-download-btn:hover:not(:disabled),.breadcrumb-download-btn:focus-visible:not(:disabled){background:var(--delete-btn-hover-bg);border-color:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}.breadcrumb-download-btn:disabled{opacity:.45;cursor:progress}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;max-width:var(--width-max);margin:0 auto;padding:0 10px}.album-empty-state{max-width:560px;margin:16px auto 0;padding:28px 24px;border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface-gradient-start),var(--surface-gradient-end));box-shadow:var(--shadow-soft);text-align:center}.album-empty-title{color:var(--text);font-size:1.05rem;font-weight:700;letter-spacing:.04em}.album-empty-copy{margin:10px 0 18px;color:var(--muted)}.album-empty-state .btn-save{margin:0 auto}.album-card{--album-card-action-size: 30px;--album-card-action-gap: 6px;--album-card-action-offset: 8px;position:relative;border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface-gradient-start),var(--surface-gradient-end));box-shadow:var(--shadow-soft);overflow:hidden;cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.album-card:hover{transform:translateY(-3px);border-color:var(--accent)}:is(.album-card-download,.album-card-delete,.album-card-rename,.album-card-access,.delete-btn,.gallery-access-btn){position:absolute;top:8px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast)}.album-card-download,.album-card-delete,.album-card-rename,.album-card-access{z-index:4;width:var(--album-card-action-size);height:var(--album-card-action-size);border:1px solid var(--accent-alpha-35);background:var(--surface-action-bg);color:var(--accent-bright);font-size:1rem;line-height:1}.album-card:is(:hover,:focus-within) :is(.album-card-download,.album-card-delete,.album-card-rename,.album-card-access),.gallery-item:is(:hover,:focus-within) :is(.delete-btn,.gallery-access-btn),.deleted-card:is(:hover,:focus-within) .delete-btn{opacity:1;pointer-events:auto}:is(.album-card-download,.album-card-delete,.album-card-rename,.album-card-access,.delete-btn,.gallery-access-btn):is(:hover,:focus-visible):not(:disabled){background:var(--delete-btn-hover-bg);border-color:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}.album-card-download{right:calc(var(--album-card-action-offset) + var(--album-card-action-size) + var(--album-card-action-gap))}.album-card-download.unassigned,.album-card-delete{right:var(--album-card-action-offset)}.album-card-rename{right:calc(var(--album-card-action-offset) + (var(--album-card-action-size) + var(--album-card-action-gap)) * 2)}.album-card-access{right:calc(var(--album-card-action-offset) + (var(--album-card-action-size) + var(--album-card-action-gap)) * 3)}.album-card-download:disabled,.album-card-delete:disabled,.album-card-rename:disabled,.album-card-access:disabled{opacity:.45;cursor:not-allowed}.album-card-badge,.gallery-item-badge{position:absolute;top:8px;left:8px;z-index:4;width:30px;height:30px;border-radius:999px;border:1px solid var(--accent-alpha-35);background:var(--surface-badge-bg);color:var(--accent-bright);display:inline-flex;align-items:center;justify-content:center}.album-card-badge.restricted,.gallery-item-badge.restricted{border-color:var(--accent-alpha-35);background:var(--surface-badge-bg);color:var(--accent-bright)}.album-card-preview{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;aspect-ratio:1 / 1;gap:2px;background:var(--surface-subtle-bg);padding:2px}.album-card-thumb{min-width:0;min-height:0;background:var(--surface-card-inner);overflow:hidden}:is(.album-card-thumb,.gallery-thumb,.deleted-card-preview,.deleted-media-preview) :is(img,video){width:100%;height:100%;object-fit:cover;display:block}.album-card-thumb.placeholder{background:linear-gradient(135deg,var(--surface-gradient-soft-start),var(--surface-gradient-soft-end))}.album-card-meta{padding:10px 12px 12px}.album-card-name{color:var(--text);font-weight:700;font-size:.95rem}.album-card-count{color:var(--muted);font-size:.8rem;margin-top:4px;text-transform:uppercase;letter-spacing:.06em}.gallery-item:nth-child(4n+1) .gallery-thumb{background-color:var(--gallery-tone-1)}.gallery-item:nth-child(4n+2) .gallery-thumb{background-color:var(--gallery-tone-2)}.gallery-item:nth-child(4n+3) .gallery-thumb{background-color:var(--gallery-tone-3)}.gallery-item:nth-child(4n+4) .gallery-thumb{background-color:var(--gallery-tone-4)}.gallery-thumb img,.gallery-thumb video{background:transparent;opacity:1;transition:opacity .3s ease-in-out}.gallery-item.selected .gallery-thumb img,.gallery-item.selected .gallery-thumb video,.gallery-item.selected .gallery-thumb .gallery-media-placeholder,.gallery-item.selected .gallery-thumb .video-thumbnail-fallback{animation:bulk-shake 1.75s ease-in-out infinite;transform-origin:50% 50%}.gallery-media-placeholder{width:100%;height:100%;background:linear-gradient(120deg,var(--gallery-placeholder-start),var(--gallery-placeholder-mid) 45%,var(--gallery-placeholder-end))}.video-thumbnail-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;background:linear-gradient(145deg,var(--surface-gradient-soft-start),var(--surface-gradient-soft-end)),linear-gradient(120deg,var(--gallery-placeholder-start),var(--gallery-placeholder-mid) 45%,var(--gallery-placeholder-end));color:var(--muted);text-align:center}.video-thumbnail-fallback.compact{padding:6px}.video-thumbnail-fallback-label{display:inline-block;max-width:100%;font-size:.76rem;font-weight:700;line-height:1.3;letter-spacing:.08em;text-transform:uppercase}.video-thumbnail-fallback.compact .video-thumbnail-fallback-label{font-size:.58rem;letter-spacing:.06em}.gallery-item:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:var(--shadow-soft)}.gallery-item.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary)}.select-checkbox{position:absolute;top:8px;left:8px;width:22px;height:22px;background:var(--select-checkbox-bg);border:2px solid var(--text-muted);border-radius:4px;z-index:10;display:none}.gallery-item.selected .select-checkbox,.bulk-mode .select-checkbox{display:block}.gallery-item.selected .gallery-item-badge,.bulk-mode .gallery-item-badge{left:36px}.gallery-item.selected .select-checkbox{background:var(--primary);border-color:var(--primary)}.gallery-item.selected .select-checkbox:after{content:"\2713";color:var(--accent-ink);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700;font-size:14px}.delete-btn,.gallery-access-btn{width:28px;height:28px;background:var(--delete-btn-bg);border:1px solid var(--delete-btn-border);color:var(--accent-bright);z-index:10;cursor:pointer}.delete-btn{right:8px;color:var(--danger)}.gallery-access-btn{right:42px}.gallery-access-btn.restricted{border-color:var(--accent-alpha-35);background:var(--surface-badge-bg);color:var(--accent-bright)}.delete-btn:hover,.delete-btn:focus-visible{color:var(--danger)}.gallery-access-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.gallery-dim-label{position:absolute;right:8px;bottom:8px;z-index:9;padding:2px 8px;border-radius:999px;background:var(--gallery-dim-label-bg);color:var(--text-white);font-size:.72rem;font-weight:600;line-height:1.3;letter-spacing:.01em;pointer-events:none;backdrop-filter:blur(1px)}.gallery-album-label{position:absolute;left:8px;bottom:8px;z-index:9;max-width:calc(100% - 84px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 8px;border-radius:999px;background:var(--gallery-album-label-bg);color:var(--accent-bright);font-size:.72rem;font-weight:700;line-height:1.3;backdrop-filter:blur(1px);pointer-events:none}.delete-btn svg{width:14px;height:14px;fill:currentColor}.loading-sentinel{height:80px;width:100%;margin-top:30px;display:flex;justify-content:center;align-items:center;color:var(--muted)}.loading-sentinel.end{border-top:1px solid var(--border);margin-top:50px;padding-top:20px;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.tag-widget{display:block;padding:6px;border:1px solid var(--border);border-radius:var(--control-radius);background:var(--bg-card);min-height:var(--control-height);box-shadow:0 1px 3px var(--tag-widget-shadow-color);transition:border-color .2s,box-shadow .2s}.tag-widget:focus-within{border-color:var(--primary);box-shadow:0 0 0 1px var(--focus-ring)}.tw-chips{display:flex;flex-wrap:wrap;align-items:center;min-width:0;width:100%;gap:6px}.tw-input-wrapper{display:flex;flex:1 1 10rem;min-width:min(100%,10rem);align-items:center}.tw-input-wrapper input{border:none;background:transparent;padding:0 8px;min-height:30px;min-width:0;width:100%;flex:1 1 auto}.tw-input-wrapper input:focus{box-shadow:none}.tw-cloud-btn{background:transparent;color:var(--text-muted);padding:4px;display:flex;align-items:center;border-radius:4px}.tw-cloud-btn:hover{color:var(--primary);background:var(--tag-cloud-btn-hover-bg)}.tag-chip{background:var(--accent-mid);color:var(--text-white);padding:4px 10px;border-radius:12px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:6px;min-width:0;max-width:100%;white-space:nowrap}.preview-status-copy{color:var(--preview-status)}.tag-chip>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-chip .close{cursor:pointer;opacity:.6;font-size:1.1rem;line-height:.8;user-select:none}.tag-chip .close:hover{opacity:1}.modal,.lightbox{display:flex;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--overlay);z-index:2000;align-items:center;justify-content:center;backdrop-filter:blur(5px);padding:12px}#tagCloudModal,#albumCloudModal{z-index:2100}#albumAccessModal{z-index:2150}#capturedOnDetectModal{z-index:2300}.app-dialog-overlay{z-index:2200}.modal-content,.bulk-modal{background:var(--card);padding:16px;border-radius:var(--radius-xl);width:100%;max-width:500px;border:1px solid var(--border);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:10px;max-height:80vh}.bulk-admin-field{display:flex;flex-direction:column;gap:4px}.bulk-admin-field input[type=date],.bulk-user-select{width:100%}.captured-on-input-actions{display:flex;align-items:flex-start;gap:10px;width:100%}.captured-on-input-stack{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px}.captured-on-detect-btn{flex:0 0 auto;min-height:var(--control-height);padding:0 14px;gap:8px;white-space:nowrap}.captured-on-detect-btn svg{width:16px;height:16px}.detected-date-content{width:min(980px,calc(100vw - 24px));max-width:980px;gap:14px}.detected-date-table-wrap{border:1px solid var(--border);border-radius:18px;background:var(--surface-card-inner);overflow:auto}.detected-date-table{width:100%;min-width:760px;border-collapse:collapse}.detected-date-table th,.detected-date-table td{padding:12px 14px;border-bottom:1px solid var(--border-card);text-align:left;vertical-align:middle}.detected-date-table thead th{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:color-mix(in srgb,var(--bg-card) 88%,var(--bg-black) 12%);position:sticky;top:0;z-index:1}.detected-date-table tbody tr:last-child td{border-bottom:none}.detected-date-thumb-cell{width:92px}.detected-date-thumb,.detected-date-thumb-placeholder{width:68px;height:68px;border-radius:14px}.detected-date-thumb{object-fit:cover;background:var(--surface-gradient-start);border:1px solid var(--border-card);display:block}.detected-date-thumb-placeholder{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--surface-gradient-start),var(--surface-gradient-end));border:1px solid var(--border-card);color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.detected-date-id{font-family:var(--font-mono);font-size:.8rem;word-break:break-word}.detected-date-change{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:var(--font-mono);font-size:.82rem}.detected-date-arrow{color:var(--text-muted)}.detected-date-change .is-updated{color:var(--accent-bright);font-weight:700}.detected-date-source{margin-top:4px;color:var(--text-muted);font-size:.78rem}#settingsModal .modal-content{max-width:860px;overflow:hidden}.app-dialog-content{width:min(560px,calc(100vw - 24px));max-width:560px;background:linear-gradient(180deg,var(--bg-tooltip) 0%,var(--bg-card) 100%);box-shadow:var(--shadow-tooltip);gap:14px}.app-dialog-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.app-dialog-title{margin:0;line-height:1.2}.app-dialog-copy{margin:0;color:var(--text-light);white-space:pre-wrap}.app-dialog-range{display:flex;flex-direction:column;gap:10px}.app-dialog-select{display:flex;flex-direction:column;gap:8px}.app-dialog-range-head,.app-dialog-range-scale{display:flex;align-items:center;justify-content:space-between;gap:10px}.app-dialog-range-label,.app-dialog-range-value{font-size:.95rem}.app-dialog-select-label{font-size:.95rem;font-weight:600}.app-dialog-range-scale,.app-dialog-range-hint,.app-dialog-select-hint{color:var(--text-light);font-size:.88rem}.app-dialog-range-input{width:100%;accent-color:var(--accent)}.app-dialog-range-hint,.app-dialog-select-hint{margin:0}.app-dialog-select-input,.app-dialog-input{width:100%}.app-dialog-actions{margin-top:2px;flex-wrap:wrap}.app-dialog-actions .btn-view,.app-dialog-actions .btn-save{min-width:110px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border);padding:0 2px 8px;margin:0 0 4px}.modal-header h3{margin:0;line-height:1.2}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:6px;border-top:1px solid var(--border)}.settings-tabs{display:inline-flex;align-items:center;gap:6px;padding:4px;border:1px solid var(--border);border-radius:999px;background:var(--settings-tabs-bg);align-self:flex-start}.settings-tab{border:0;background:transparent;color:var(--text-muted);padding:8px 14px;border-radius:999px;font-size:.82rem;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.settings-tab:hover{color:var(--text);background:var(--settings-tab-hover-bg)}.settings-tab.active{background:var(--accent);color:var(--accent-ink);box-shadow:var(--settings-tab-active-shadow)}.settings-tab-panel{display:flex;flex-direction:column;gap:10px;min-height:0}.settings-field-header,.login-label,.upload-controls label,.modal-content label,.lightbox-sidebar label{display:block;margin:8px 0 0;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.close-modal{font-size:24px;cursor:pointer;line-height:1;color:var(--muted);padding:2px 4px}.close-modal:hover{color:var(--text-white)}.cloud-tags-container{display:flex;flex-wrap:wrap;gap:6px;overflow-y:auto;padding:2px;max-height:60vh}.cloud-tag{background:var(--accent-deep);color:var(--text-light);padding:6px 12px;border-radius:20px;border:1px solid var(--accent-muted);font-size:.9rem;user-select:none;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.cloud-tag:hover{border-color:var(--accent-border);background:var(--cloud-tag-hover-bg)}.cloud-tag.selected{background:var(--accent);color:var(--accent-ink);border-color:var(--accent-bright);box-shadow:var(--cloud-tag-selected-shadow);font-weight:700}.album-access-content{max-width:640px}.album-access-target{color:var(--text-strong);font-size:1rem;font-weight:700}.album-access-copy{margin:.35rem 0 0;color:var(--text-dim)}.album-access-status{display:inline-flex;align-items:center;gap:.35rem;margin:.85rem 0 .25rem;padding:.35rem .65rem;border-radius:999px;font-size:.8rem;border:1px solid var(--album-access-status-border);background:var(--album-access-status-bg);color:var(--accent-bright)}.album-access-status.public{border-color:var(--success-alpha-28);background:var(--success-alpha-10);color:var(--success)}.album-access-status.mixed{border-color:var(--muted-alpha-28);background:var(--white-alpha-07);color:var(--text-dim)}.album-access-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}.lb-access-block,.bulk-viewer-access{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.cloud-tag-delete{border-radius:999px;border:1px solid var(--cloud-delete-border);background:var(--cloud-delete-bg);color:inherit;padding:2px 8px;font-size:.72rem;font-weight:700}.cloud-tag-delete{width:24px;height:24px;padding:0;display:inline-flex;align-items:center;justify-content:center}.cloud-tag-delete:hover{background:var(--cloud-delete-hover-bg)}.lightbox-content{display:grid;grid-template-columns:1fr 350px;width:95%;max-width:1600px;height:90vh;background:var(--card);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-soft)}.lightbox-media-area{background:var(--bg-black);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.lightbox-media-area img,.lightbox-media-area video{width:100%;height:100%;object-fit:contain}.lightbox-sidebar{background:var(--panel);border-left:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;position:relative;z-index:10}.close-lightbox{position:absolute;top:15px;right:15px;width:40px;height:40px;background:var(--close-lightbox-bg);border-radius:50%;color:var(--text-white);display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;z-index:100}.close-lightbox:hover{background:var(--primary);color:var(--accent-ink)}.lb-section-title{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:4px}.lb-id-control{margin-bottom:10px}.lb-id-field{position:relative;min-width:0}.lb-id-input,.lb-file-name-input{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.01em}.lb-id-input{width:100%}.lb-id-field.has-action .lb-id-input{padding-right:48px}.lb-id-refresh{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:28px;height:28px;padding:0;border:1px solid var(--lb-refresh-border);background:var(--lb-refresh-bg);color:var(--accent-border);box-shadow:var(--lb-refresh-shadow)}.lb-id-refresh:hover:not(:disabled){color:var(--accent-bright);border-color:var(--lb-refresh-hover-border);background:var(--lb-refresh-hover-bg)}.lb-id-refresh:disabled{opacity:.6;cursor:not-allowed}.lb-id-refresh svg{width:15px;height:15px}.lb-id-refresh svg.is-spinning{animation:icon-spin .9s linear infinite}.lb-file-name{padding:10px 12px;border-radius:var(--control-radius);border:1px solid var(--border);background:var(--surface-card-inner);color:var(--text);font-size:.84rem;font-weight:600;line-height:1.4;user-select:text}.lb-file-name-input{white-space:nowrap;overflow-x:auto;overflow-y:hidden;text-overflow:clip;scrollbar-width:thin;scrollbar-color:var(--primary) transparent}.preview-settings-panel,.lightbox-sidebar-sections{display:flex;flex-direction:column;gap:12px}.preview-settings-note{margin:-2px 0 0;color:var(--text-muted);font-size:.82rem}.preview-settings-meta{margin-top:2px}.control-group{display:flex;flex-direction:column;gap:4px}.control-group input,.control-group select{width:100%}.settings-toggle-row{display:inline-flex;align-items:center;cursor:pointer}.settings-toggle-control{position:relative;flex:0 0 auto;display:inline-block;width:60px;height:34px}.settings-toggle-input{position:absolute;width:0;height:0;margin:0;opacity:0}.settings-toggle-switch{position:absolute;cursor:pointer;inset:0;border-radius:34px;background:var(--toggle-track-bg);border:1px solid var(--toggle-track-border);box-shadow:var(--toggle-track-shadow);transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast)}.settings-toggle-switch:after{content:"";position:absolute;left:4px;bottom:3px;width:26px;height:26px;border-radius:50%;background:linear-gradient(180deg,var(--toggle-thumb-bg-start) 0%,var(--toggle-thumb-bg-end) 100%);box-shadow:var(--toggle-thumb-shadow);transition:transform var(--transition-fast),background var(--transition-fast)}.settings-toggle-row:hover .settings-toggle-switch{background:var(--toggle-track-hover-bg);border-color:var(--toggle-track-hover-border)}.settings-toggle-input:focus-visible+.settings-toggle-switch{box-shadow:var(--toggle-focus-shadow)}.settings-toggle-input:checked+.settings-toggle-switch{background:linear-gradient(180deg,var(--toggle-on-bg-start) 0%,var(--toggle-on-bg-end) 100%);border-color:var(--toggle-on-border);box-shadow:var(--toggle-on-shadow)}.settings-toggle-input:checked+.settings-toggle-switch:after{transform:translate(26px);background:linear-gradient(180deg,var(--toggle-thumb-on-bg-start) 0%,var(--toggle-thumb-on-bg-end) 100%)}.settings-toggle-note{margin:0;font-size:.78rem;line-height:1.45;transition:color var(--transition-fast)}.settings-toggle-note.is-on{color:var(--toggle-note-on)}.settings-toggle-note.is-off{color:var(--text-muted)}.admin-users-panel{display:flex;flex-direction:column;gap:12px;padding-top:6px;min-height:0}.settings-history-panel{display:flex;flex-direction:column;gap:12px;min-height:0;padding-top:6px}.settings-history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.settings-history-header-actions{display:flex;flex:0 0 auto;justify-content:flex-end}.deleted-page-shell{width:min(100%,var(--width-max));margin:0 auto;display:flex;flex-direction:column;gap:16px}.deleted-page-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-radius:var(--radius-xl);border:1px solid var(--border);background:linear-gradient(180deg,var(--surface-gradient-soft-start) 0%,var(--surface-gradient-soft-end) 100%),var(--card);box-shadow:var(--shadow-soft)}.deleted-page-toolbar-copy{min-width:0;display:flex;flex-direction:column;gap:6px}.deleted-page-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.deleted-page-title{font-size:clamp(1.3rem,2vw,1.75rem);font-weight:800;color:var(--text);letter-spacing:-.02em}.deleted-page-toolbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.deleted-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}.deleted-card{position:relative;min-width:0;overflow:hidden;border-radius:var(--radius-xl);border:1px solid var(--border);background:linear-gradient(180deg,var(--surface-gradient-start) 0%,var(--surface-gradient-end) 100%);box-shadow:var(--shadow-soft);transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.deleted-card:hover{transform:translateY(-2px);border-color:var(--accent-border)}.deleted-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary)}.deleted-card.selected .select-checkbox{background:var(--primary);border-color:var(--primary)}.deleted-card .select-checkbox{display:block}.deleted-card.selected .select-checkbox:after{content:"\2713";color:var(--accent-ink);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700;font-size:14px}.deleted-card-preview,.deleted-media-preview{overflow:hidden;background:var(--accent-alpha-04)}.deleted-card-preview{position:relative;aspect-ratio:.92 / 1}.deleted-card-type-badge{position:absolute;top:10px;left:10px;z-index:1;background:#0a0e131a;border-color:#ffffff1f;color:#fff}.deleted-card-info{position:absolute;right:0;bottom:0;left:0;display:flex;flex-direction:column;gap:9px;padding:44px 12px 12px;background:linear-gradient(180deg,#0a0e1300,#0a0e1352 18%,#0a0e13c2)}.deleted-card-id-field{display:block;width:100%;min-width:0}.deleted-card-id-input{display:block;width:100%;min-width:0;box-sizing:border-box;height:32px;padding:0 10px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:#0a0e1352;box-shadow:inset 0 1px #ffffff0a;font-family:var(--font-mono);font-size:.72rem;font-weight:700;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;outline:none}.deleted-card-id-input::selection{background:#ffffff3d}.deleted-card-info-lines,.deleted-media-lines{display:flex;flex-direction:column}.deleted-card-info-lines{gap:6px}.deleted-card-info-line{display:flex;align-items:flex-start;gap:12px;color:#ffffffeb;font-size:.7rem;line-height:1.35;min-width:0}.deleted-card-info-line strong{flex:0 0 auto;color:#fff;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;padding-top:1px;white-space:nowrap}.deleted-card-info-line span{min-width:0;margin-left:auto;text-align:right;word-break:break-word}.deleted-media-panel{display:flex;flex-direction:column;gap:12px;min-height:0;padding-top:6px}.settings-history-copy{margin:4px 0 0;color:var(--text-muted);font-size:.84rem;line-height:1.5}.settings-history-empty{padding:16px;border-radius:var(--radius-lg);border:1px dashed var(--border);background:var(--admin-panel-bg);color:var(--text-muted)}.settings-history-list{display:flex;flex-direction:column;gap:10px;min-height:0;max-height:min(46vh,460px);overflow-y:auto;padding-right:2px}.settings-history-entry{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--admin-row-bg)}.settings-history-entry.is-undone{opacity:.82}.settings-history-entry-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.settings-history-entry-copy{min-width:0;display:flex;flex-direction:column;gap:6px}.settings-history-entry-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.settings-history-entry-title{font-weight:700;color:var(--text);word-break:break-word}.settings-history-entry-status{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:3px 10px;border-radius:999px;border:1px solid var(--admin-pill-border);background:var(--admin-pill-bg);font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.settings-history-entry-status.is-pending{border-color:var(--admin-pill-highlight-border);color:var(--accent-bright)}.settings-history-entry-status.is-undone{color:var(--text-muted)}.settings-history-entry-description{margin:0;color:var(--text-light);font-size:.88rem;line-height:1.45}.settings-history-entry-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--text-muted);font-size:.75rem;letter-spacing:.03em}.settings-history-entry-actions{display:flex;gap:8px;flex-wrap:wrap}.settings-history-items{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow-y:auto;padding-top:10px;padding-right:2px;border-top:1px solid var(--border)}.settings-history-item{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--accent-alpha-04)}.settings-history-item-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-history-item-title{font-family:var(--font-mono);font-size:.82rem;color:var(--text);word-break:break-all}.settings-history-item-type{color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.settings-history-item-lines{display:flex;flex-direction:column;gap:4px;max-height:110px;overflow-y:auto}.settings-history-item-line{color:var(--text-light);font-size:.82rem;line-height:1.45;word-break:break-word}.settings-section-title{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}.admin-user-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;align-items:end}.password-change-form,.admin-password-form{grid-template-columns:repeat(4,minmax(0,1fr))}.bootstrap-admin-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto}.admin-user-form .btn-save{width:100%}.bootstrap-admin-form .btn-save{align-self:end;width:auto;min-width:180px}.admin-user-password-panel{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--admin-panel-bg)}.admin-users-list{display:flex;flex-direction:column;flex:1 1 auto;gap:10px;min-height:0;max-height:min(42vh,420px);overflow-y:auto;padding-right:2px}.deleted-media-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.deleted-media-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.deleted-media-list{display:flex;flex-direction:column;gap:10px;min-height:0;max-height:min(46vh,460px);overflow-y:auto;padding-right:2px}.deleted-media-row{display:grid;grid-template-columns:92px minmax(0,1fr) auto;gap:12px;align-items:flex-start;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--admin-row-bg)}.deleted-media-preview{width:92px;height:92px;border-radius:var(--radius-lg);border:1px solid var(--border)}.deleted-media-preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:8px;color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;text-align:center}.deleted-media-copy{min-width:0;display:flex;flex-direction:column;gap:8px}.deleted-media-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.deleted-media-title{font-family:var(--font-mono);font-size:.88rem;font-weight:700;color:var(--text);word-break:break-all}.deleted-media-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--text-muted);font-size:.76rem;letter-spacing:.03em}.deleted-media-lines{gap:4px}.deleted-media-line{color:var(--text-light);font-size:.84rem;line-height:1.45;word-break:break-word}.deleted-media-line strong{color:var(--text)}.deleted-media-actions{display:flex;align-items:center;justify-content:flex-end}.deleted-media-footer{display:flex;justify-content:center}.deleted-review-modal{max-width:980px;overflow:hidden}.deleted-review-copy{margin:0;color:var(--text-light);line-height:1.5}.deleted-review-list{max-height:min(55vh,560px)}.deleted-review-actions{gap:8px;flex-wrap:wrap}.deleted-review-footer{align-items:center}.admin-user-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--admin-row-bg)}.admin-user-meta{min-width:0;display:flex;flex-direction:column;gap:6px}.admin-user-name{font-weight:700;color:var(--text);word-break:break-word}.admin-user-theme-control{max-width:320px}.admin-user-theme-select{min-width:220px}.admin-user-status,.admin-user-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.admin-user-pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid var(--admin-pill-border);background:var(--admin-pill-bg);color:var(--text-light);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.admin-user-pill.admin,.admin-user-pill.enabled{border-color:var(--admin-pill-highlight-border);color:var(--accent-bright)}.admin-user-pill.guest{border-color:var(--admin-pill-guest-border);color:var(--muted)}.admin-user-pill.disabled{border-color:var(--admin-pill-disabled-border);color:var(--muted)}.lb-meta-grid{display:grid;grid-template-columns:auto 1fr;gap:5px 15px;font-size:.9rem}.lb-meta-label{color:var(--text-muted);font-weight:500}.lb-meta-value{font-family:monospace;word-break:break-all}.lb-meta-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.lb-meta-title{color:var(--text-muted);font-size:.9rem;font-weight:500}.lb-meta-field input[type=date]{width:100%}.inkplate-simulated{filter:grayscale(100%) contrast(110%) brightness(95%) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.60 0'/%3E%3CfeBlend in='SourceGraphic' mode='multiply'/%3E%3C/filter%3E%3C/svg%3E#grain")}@media(max-width:900px){.deleted-page-toolbar{flex-direction:column;align-items:stretch}.deleted-page-toolbar-actions{justify-content:stretch}.deleted-page-toolbar-actions>*{flex:1 1 140px}.deleted-card-grid,.admin-user-form{grid-template-columns:1fr}.captured-on-input-actions{flex-direction:column;align-items:stretch}.captured-on-detect-btn{width:100%;justify-content:center}.detected-date-content{width:calc(100vw - 16px);max-height:85vh}.deleted-media-toolbar,.settings-history-entry-head,.admin-user-row,.settings-history-header{flex-direction:column;align-items:stretch}.deleted-media-row{grid-template-columns:1fr}.deleted-media-preview{width:100%;max-width:220px;height:160px}.settings-history-header-actions>*,.settings-history-entry-actions>*,.admin-user-actions>*{flex:1 1 140px}.deleted-media-actions>*{width:100%}.deleted-review-actions>*{flex:1 1 140px}.settings-history-item-title-row{align-items:flex-start;flex-direction:column}.admin-user-theme-select{min-width:0;width:100%}}.upload-container{max-width:1000px;margin:0 auto;background:var(--card);padding:2rem;border-radius:var(--radius-xl);border:1px solid var(--border-card);box-shadow:var(--shadow-soft)}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}#dropZone{border:2px dashed var(--border);border-radius:8px;padding:2rem;display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:350px;background:var(--dropzone-bg);transition:all .2s;cursor:pointer;position:sticky;top:20px}#dropZone.hover{border-color:var(--primary);background:var(--dropzone-hover-bg)}.hidden-input{display:none}.upload-controls{display:flex;flex-direction:column;gap:6px;min-width:0}.upload-controls>select,.upload-controls>input[type=text],.upload-controls>input[type=number],.upload-controls>input[type=date],.upload-controls>.tag-widget,.upload-controls>widget-tags,.upload-controls>widget-albums{width:100%}.upload-controls select,.upload-controls input[type=text],.upload-controls input[type=number],.upload-controls input[type=date]{min-height:var(--control-height)}.upload-controls .tag-widget{min-height:var(--control-height);max-height:none;overflow:visible}.upload-controls .tw-chips{max-width:100%;align-content:flex-start}.upload-controls .tw-input-wrapper,.upload-controls .tw-input-wrapper input{min-height:30px}.custom-resolution-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.custom-resolution-grid>div{display:flex;flex-direction:column;gap:6px}.custom-resolution-grid input[type=number]{width:100%;min-height:var(--control-height)}#pendingScroll,#uploadedScroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:10px;margin-bottom:10px;scrollbar-width:thin;scrollbar-color:var(--primary) var(--bg)}#uploadedContainer{margin-top:16px}.pending-item{width:136px;flex-shrink:0;background:var(--pending-item-bg);border:1px solid var(--border);border-radius:8px;overflow:hidden;position:relative;display:flex;flex-direction:column}.uploaded-item{cursor:pointer}.pending-media{position:relative;width:100%;height:96px;background:var(--bg-black)}.pending-thumb{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;background:var(--bg-black);cursor:zoom-in;transition:opacity .2s}.pending-item-footer{padding:8px;border-top:1px solid var(--border-soft, rgba(255, 255, 255, .06));background:var(--pending-item-bg)}.pending-item-name{color:var(--text);font-size:.74rem;font-weight:600;line-height:1.35;user-select:text}.pending-controls{position:absolute;left:6px;right:6px;bottom:6px;display:flex;gap:4px;z-index:10;align-items:center}.remove-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;background:var(--surface-action-bg);color:var(--accent-bright);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;font-size:14px;border:1px solid var(--accent-border);z-index:20;transition:transform .1s;padding:0;line-height:1;pointer-events:auto}.section-label{display:block;color:var(--text-muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.remove-btn:hover{background:var(--delete-btn-hover-bg);color:var(--accent-ink);transform:scale(1.1)}.upload-controls .mode-select-mini{width:calc(100% - 30px);min-width:0;height:26px;min-height:26px;padding:0 6px;font-size:.74rem;background:var(--pending-control-bg);color:var(--text-white);border:1px solid var(--accent-border);border-radius:4px}.rotate-btn{width:26px;height:26px;background:var(--pending-control-bg);color:var(--text-white);border:1px solid var(--accent-border);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px}.rotate-btn:hover{border-color:var(--primary);color:var(--text-white)}.progress-container{width:100%;margin-top:15px;background:var(--progress-track-bg);border-radius:8px;border:1px solid var(--border);height:32px;position:relative;overflow:hidden}.progress-text-back,.progress-text-front{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;white-space:nowrap}.progress-text-back{color:var(--text-white);z-index:1}.progress-bar{position:absolute;top:0;left:0;height:100%;background:var(--primary);width:0%;transition:width .2s;overflow:hidden;z-index:2}.progress-text-front{color:var(--accent-ink)}.progress-detail{margin-top:8px;font-size:.82rem;color:var(--text-light);text-align:center}.bulk-toolbar{position:fixed;bottom:0;left:50%;transform:translate(-50%) translateY(100%);width:100%;max-width:var(--width-max);background:var(--card);padding:15px 30px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transition:transform .3s;z-index:1000;box-shadow:var(--bulk-toolbar-shadow)}.bulk-toolbar.show{transform:translate(-50%) translateY(0)}.bulk-info{font-weight:600;color:var(--primary)}.bulk-actions-shell,.bulk-actions{display:flex;gap:10px;flex-wrap:wrap}.toast{visibility:hidden;min-width:300px;background-color:var(--toast-bg);color:var(--text-white);text-align:center;border-radius:8px;padding:16px;position:fixed;z-index:3000;left:50%;transform:translate(-50%);bottom:30px;border:1px solid var(--toast-border);opacity:0;transition:opacity .3s,bottom .3s}.toast.show{visibility:visible;opacity:1;bottom:50px}.toast.success{border-color:var(--toast-success-color);color:var(--toast-success-color);background:linear-gradient(180deg,var(--toast-success-bg-start),var(--toast-success-bg-end))}.toast.warning{border-color:var(--toast-warning-color);color:var(--toast-warning-color);background:linear-gradient(180deg,var(--toast-warning-bg-start),var(--toast-warning-bg-end))}.toast.error{border-color:var(--toast-error-color);color:var(--toast-error-color);background:linear-gradient(180deg,var(--toast-error-bg-start),var(--toast-error-bg-end))}@media(max-width:900px){.header-container{gap:8px;margin-bottom:12px;padding:8px;flex-direction:column;align-items:stretch}.header-container.drawer-open{gap:8px}.header-primary{order:1;display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-width:0}.header-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:nowrap;gap:8px;width:auto;flex:0 0 auto}.header-actions .select-btn,.header-actions .btn-icon-clear{margin:0}.header-actions .select-btn,.header-actions .tag-filter-btn{width:36px;min-width:36px;flex:0 0 36px}.header-action-btn{width:36px;height:36px;border-radius:12px}.header-drawer-toggle{display:inline-flex;align-items:center;justify-content:center;width:auto;min-width:0;flex:1 1 auto;min-height:36px;padding:8px 12px;font-size:.74rem;letter-spacing:.05em}.header-controls{order:2;width:100%;max-height:0;overflow:hidden;opacity:0;pointer-events:none;transition:max-height .25s ease,opacity .2s ease;gap:10px;align-items:stretch}.header-controls.open{max-height:960px;opacity:1;pointer-events:auto;overflow:visible}.header-controls>select,.gallery-filter-menu,.gallery-search-control,.header-controls .tag-widget{flex:1 1 100%;min-width:0}.gallery-search-control{flex:1 1 100%;width:100%;max-width:none}.gallery-search-input{width:100%;max-width:none}.gallery-filter-panel{position:static;width:100%;max-height:min(320px,45vh);margin-top:8px}.lightbox-content{grid-template-columns:1fr;grid-template-rows:1fr auto;height:100vh;width:100%;border-radius:0}.lightbox-sidebar{height:50vh;border-left:none;border-top:1px solid var(--border);order:2}.lightbox-media-area{height:50vh;order:1}.lightbox.preview-mode.preview-config-mode .lightbox-content{grid-template-columns:1fr;grid-template-rows:1fr auto}.close-lightbox{top:10px;right:10px;user-select:none}.upload-grid,.custom-resolution-grid{grid-template-columns:1fr}#dropZone{min-height:200px;position:static}.bulk-toolbar{border-radius:0;padding:10px 20px;flex-direction:column;gap:10px}.bulk-actions{width:100%;justify-content:space-between}.bulk-actions button{flex-grow:1}.gallery-breadcrumbs{margin-bottom:12px}}@media(max-width:768px){.app-nav{padding:.75rem .9rem}.nav-brand{min-width:0;font-size:.88rem;letter-spacing:.06em}.nav-auth-actions{margin-left:auto;gap:.5rem}.nav-menu-toggle{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center}.nav-links{position:absolute;top:calc(100% + 8px);right:.9rem;left:.9rem;display:none;flex-direction:column;align-items:stretch;gap:8px;padding:10px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--bg),var(--bg-header-end));box-shadow:var(--shadow-soft)}.nav-links.open{display:flex}.nav-mobile-actions{gap:.4rem}.nav-btn{min-height:34px;padding:0 12px;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--bg-card) 82%,transparent);font-size:.74rem;letter-spacing:.05em;justify-content:center}.nav-btn:after{display:none}.nav-btn.active{background:var(--accent-alpha-16);border-color:var(--accent-alpha-45)}.nav-settings-btn,.nav-menu-toggle{width:34px;height:34px;padding:0;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--bg-card) 82%,transparent);display:inline-flex;align-items:center;justify-content:center}.nav-settings-btn svg,.nav-menu-toggle svg{display:block;width:18px;height:18px}}@media(max-width:480px){.header-container,.header-controls{flex-direction:column;align-items:stretch}.gallery-grid{grid-template-columns:1fr}.btn-view,.btn-save,.select-btn,.btn-link{width:100%;display:flex;justify-content:center;margin-bottom:10px;box-sizing:border-box}.header-container .select-btn{margin-right:0}.header-actions{gap:6px}.header-actions .select-btn,.header-actions .btn-icon-clear{width:auto;margin-bottom:0}.header-actions .header-action-btn,.header-actions .tag-filter-btn{width:34px;min-width:34px;flex-basis:34px;height:34px;border-radius:11px}.header-drawer-toggle{min-height:34px;padding:8px 10px;font-size:.72rem}.captured-on-input-actions .btn-view,.captured-on-input-actions .btn-save{margin-bottom:0}}.btn-view.active{background:var(--primary);color:var(--accent-ink);border-color:var(--primary)}.error-icon-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--danger)}.error-icon-container svg{animation:error-pulse 1.1s ease-in-out infinite}@keyframes error-pulse{0%{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1)}to{opacity:.55;transform:scale(.92)}}@keyframes bulk-shake{0%{transform:translateZ(0) rotate(0)}25%{transform:translate3d(-1px,0,0) rotate(-.5deg)}50%{transform:translate3d(1px,0,0) rotate(.45deg)}75%{transform:translate3d(-.5px,0,0) rotate(-.35deg)}to{transform:translateZ(0) rotate(0)}}.lightbox.preview-mode .lightbox-sidebar{display:none}.lightbox.preview-mode .lightbox-content{grid-template-columns:1fr}.lightbox.preview-mode.preview-config-mode .lightbox-sidebar{display:flex}.lightbox.preview-mode.preview-config-mode .lightbox-content{grid-template-columns:1fr 350px}#dropText{font-size:1.1rem;color:var(--text-light);pointer-events:none;text-align:center;line-height:1.4}
