:root{--bg: #f3f4f7;--surface: #ffffff;--surface-2: #eef0f4;--surface-sunken: #f7f8fa;--bg-elevated: #ffffff;--border: #e4e7ec;--border-strong: #d4d9e2;--text: #11151c;--text-dim: #5b6675;--text-faint: #8a94a3;--accent: #4f6ef7;--accent-hover: #3f5be0;--accent-soft: #ecf0fe;--danger: #e5484d;--danger-soft: #fdeced;--radius: 12px;--radius-sm: 8px;--radius-lg: 18px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.04);--shadow-md: 0 6px 16px rgba(16,24,40,.08), 0 2px 4px rgba(16,24,40,.04);--shadow-lg: 0 16px 40px rgba(16,24,40,.14), 0 4px 10px rgba(16,24,40,.06);--ring: 0 0 0 3px rgba(79,110,247,.2)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5;letter-spacing:-.011em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer}a{color:inherit}::selection{background:var(--accent-soft)}.sharing-email-list,.folder-picker__list,.modal-media,.modal-meta{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.app-header{display:flex;align-items:center;gap:20px;padding:12px 22px;background:#ffffffd1;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.app-header__brand{font-weight:650;font-size:1.05rem;letter-spacing:-.02em}.app-header__back{color:var(--text-dim);text-decoration:none;padding:7px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem;font-weight:500;background:var(--surface);transition:border-color .15s,color .15s,background .15s}.app-header__back:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-2)}.app-header__nav{display:flex;gap:4px;flex:1}.app-header__nav a{color:var(--text-dim);text-decoration:none;padding:7px 14px;border-radius:var(--radius-sm);font-weight:500;font-size:.92rem;transition:background .15s,color .15s}.app-header__nav a:hover{color:var(--text);background:var(--surface-2)}.app-header__nav a.active{color:var(--accent);background:var(--accent-soft)}.app-header__actions{display:flex;align-items:center;gap:12px}@media (max-width: 700px){.app-header{flex-wrap:wrap;gap:8px 12px;padding:10px 14px}.app-header__brand{font-size:1rem}.app-header__nav{flex:1 1 100%;order:3}.app-header__actions{flex-wrap:wrap;gap:8px}}.folder-toolbar{display:flex;align-items:center;gap:14px;padding:20px 22px 8px}.folder-breadcrumbs{flex:1;font-weight:650;font-size:1.05rem;letter-spacing:-.01em}.folder-breadcrumbs a{color:var(--text-dim);text-decoration:none;font-weight:500}.folder-breadcrumbs a:hover{color:var(--accent)}.folder-breadcrumbs__sep{color:var(--text-faint);margin:0 2px}.folder-breadcrumbs__current{color:var(--text)}.folder-breadcrumbs__link{background:none;border:none;padding:0;color:var(--text-dim);font-weight:500;font-size:1.05rem;transition:color .15s}.folder-breadcrumbs__link:hover{color:var(--accent)}.create-album-button{background:var(--accent);border:1px solid transparent;color:#fff;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;box-shadow:var(--shadow-sm);transition:background .15s,transform .1s,box-shadow .15s}.create-album-button:hover{background:var(--accent-hover)}.create-album-button:active{transform:translateY(1px)}.sharing-button{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:var(--radius-sm);font-weight:500;font-size:.88rem;transition:border-color .15s,background .15s}.sharing-button:hover{border-color:var(--border-strong);background:var(--surface-2)}.modal-content--form{width:440px;max-width:90vw;max-height:85vh;padding:24px 26px;display:flex;flex-direction:column;gap:12px}.modal-content--form h3{margin:0 0 4px;flex-shrink:0;font-size:1.15rem;letter-spacing:-.02em}.sharing-hint{margin:0;color:var(--text-dim);font-size:.82rem;line-height:1.5;flex-shrink:0}.sharing-email-list{display:flex;flex-direction:column;gap:4px;flex:1;min-height:60px;max-height:280px;overflow-y:auto}.sharing-option{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.92rem;padding:8px 10px;border-radius:var(--radius-sm);transition:background .12s}.sharing-option:hover{background:var(--surface-2)}.sharing-option input{accent-color:var(--accent);width:16px;height:16px}.sharing-option__you{color:var(--text-faint);font-size:.8rem}.sharing-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;flex-shrink:0}.sharing-actions button{padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;background:var(--accent);border:1px solid transparent;color:#fff;transition:background .15s}.sharing-actions button:hover{background:var(--accent-hover)}.sharing-actions button:first-child{background:var(--surface);border:1px solid var(--border);color:var(--text);font-weight:500}.sharing-actions button:first-child:hover{border-color:var(--border-strong);background:var(--surface-2)}.modal-content--form .folder-breadcrumbs{flex:0 0 auto}.folder-picker__list{display:flex;flex-direction:column;gap:2px;flex:1;min-height:60px;max-height:280px;overflow-y:auto}.folder-picker__item{background:transparent;border:1px solid transparent;color:var(--text);text-align:left;padding:9px 12px;border-radius:var(--radius-sm);font-size:.92rem;transition:background .12s,border-color .12s}.folder-picker__item:hover{border-color:var(--border);background:var(--surface-2)}.folder-picker__empty{color:var(--text-faint);font-size:.85rem;padding:8px 0}.thumb--folder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:10px;background:linear-gradient(160deg,#f5f7fb,#eaecf3)}.thumb__folder-icon{font-size:2.6rem;filter:drop-shadow(0 2px 4px rgba(16,24,40,.1))}.thumb__folder-name{font-size:.85rem;font-weight:500;word-break:break-word;color:var(--text)}.logout-button,.login-button{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:7px 15px;border-radius:var(--radius-sm);font-weight:500;font-size:.88rem;transition:border-color .15s,background .15s}.logout-button:hover,.login-button:hover{border-color:var(--border-strong);background:var(--surface-2)}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:14px;text-align:center;padding:24px}.login-page h1{font-size:2rem;font-weight:700;letter-spacing:-.03em;margin:0}.login-page p{color:var(--text-dim);margin:0;max-width:30ch}.login-button{padding:11px 28px;font-size:1rem;font-weight:600;margin-top:6px;background:var(--accent);border-color:transparent;color:#fff;box-shadow:var(--shadow-md)}.login-button:hover{background:var(--accent-hover);border-color:transparent}.auth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-dim)}.edit-switch{display:flex;align-items:center;gap:9px;cursor:pointer;-webkit-user-select:none;user-select:none}.edit-switch input{display:none}.edit-switch__track{width:38px;height:22px;background:var(--border-strong);border-radius:var(--radius-pill);position:relative;transition:background .18s ease}.edit-switch input:checked+.edit-switch__track{background:var(--accent)}.edit-switch__thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #1018284d;transition:transform .18s ease}.edit-switch input:checked+.edit-switch__track .edit-switch__thumb{transform:translate(16px)}.edit-switch__label{font-size:.85rem;font-weight:500;color:var(--text-dim)}.tag-filter-bar{display:flex;flex-direction:column;gap:12px;padding:14px 22px}.tag-filter-bar__search{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:var(--radius);font-size:.92rem;max-width:340px;width:100%;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.tag-filter-bar__search::placeholder{color:var(--text-faint)}.tag-filter-bar__search:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.tag-filter-bar__selected,.tag-suggestions{display:flex;flex-wrap:wrap;gap:8px}.tag-suggestions__hint{color:var(--text-faint);font-size:.85rem;padding:4px 0}.tag-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);padding:6px 13px;border-radius:var(--radius-pill);font-size:.84rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s,transform .1s}.tag-chip:hover{border-color:var(--border-strong);color:var(--text)}.tag-chip:active{transform:scale(.97)}.tag-chip--active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag-chip--active:hover{background:var(--accent-hover);color:#fff}.tag-chip__count{opacity:.65;font-size:.75rem}.tag-chip--clear{color:var(--danger);border-color:var(--danger-soft);background:var(--danger-soft)}.tag-chip--clear:hover{color:var(--danger);border-color:var(--danger)}.tag-chip--editable .tag-chip__remove{background:none;border:none;color:inherit;margin-left:2px;font-size:1rem;line-height:1;padding:0;cursor:pointer}.gallery-page{padding-bottom:90px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:16px;padding:12px 22px}.thumb-wrap{display:flex;flex-direction:column;gap:6px;min-width:0}.thumb-wrap__name{font-size:.78rem;font-weight:500;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px}.thumb{position:relative;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:var(--surface-2);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}.thumb:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-strong)}.thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s cubic-bezier(.2,.6,.2,1)}.thumb:hover img{transform:scale(1.05)}.thumb--selected{outline:3px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.thumb__video-badge{position:absolute;bottom:8px;right:8px;background:#0009;color:#fff;font-size:.7rem;font-weight:500;padding:3px 7px;border-radius:var(--radius-pill);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.thumb__checkbox{position:absolute;top:9px;left:9px;width:22px;height:22px;border:2px solid white;border-radius:6px;background:#00000040;box-shadow:0 1px 3px #00000059;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.thumb__checkbox--checked{background:var(--accent);border-color:#fff}.thumb__status-badge{position:absolute;top:8px;right:8px;background:#0000008c;padding:3px 6px;border-radius:6px;font-size:.8rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.thumb__rename,.thumb__move,.thumb__delete{position:absolute;background:#00000080;color:#fff;border:none;width:28px;height:28px;border-radius:50%;font-size:.9rem;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .15s,background .15s}.thumb:hover .thumb__rename,.thumb:hover .thumb__move,.thumb:hover .thumb__delete{opacity:1}.thumb__rename{top:8px;right:8px}.thumb__rename:hover{background:#000000c7}.thumb__move{top:8px;left:8px}.thumb__move:hover{background:#000000c7}.thumb__delete{bottom:8px;right:8px}.thumb__delete:hover{background:var(--danger)}@media (hover: none){.thumb__rename,.thumb__move,.thumb__delete{opacity:1}}.gallery-empty,.gallery-loading{padding:80px 20px;text-align:center;color:var(--text-faint);font-size:.95rem}.gallery-sentinel{height:1px}.bulk-toolbar{position:fixed;bottom:24px;left:0;right:0;margin:0 auto;width:fit-content;display:flex;flex-direction:column;gap:8px;background:#1a1d24;border:1px solid rgba(255,255,255,.08);padding:12px 18px;border-radius:var(--radius-lg);box-shadow:0 16px 40px #1018284d,0 4px 10px #10182833;z-index:30;max-width:92vw;color:#f4f5f7}.bulk-toolbar__row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bulk-toolbar input{background:#ffffff12;border:1px solid rgba(255,255,255,.14);color:#f4f5f7;padding:7px 11px;border-radius:var(--radius-sm)}.bulk-toolbar input::placeholder{color:#fff6}.bulk-toolbar input:focus{outline:none;border-color:var(--accent)}.bulk-toolbar button{background:var(--accent);border:none;color:#fff;padding:7px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;transition:background .15s}.bulk-toolbar button:hover{background:var(--accent-hover)}.bulk-toolbar__clear{background:transparent;color:#fff9}.bulk-toolbar__clear:hover{background:#ffffff14}.bulk-toolbar__count{color:#fff9;font-size:.85rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a0ed1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:50}.modal-overlay:has(.modal-content--form){align-items:flex-start;padding-top:4vh}.modal-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.modal-media{display:flex;align-items:center;justify-content:center;background:#000;width:92vw;height:78vh;overflow:auto}.modal-media img{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-in}.modal-media img.is-zoomed{max-width:none;max-height:none;cursor:zoom-out}.modal-media video{max-width:100%;max-height:100%}.modal-meta{padding:16px 20px;display:flex;flex-direction:column;gap:12px;background:var(--surface)}.modal-meta__date{color:var(--text-dim);font-size:.85rem;font-weight:500}.modal-meta__tags{display:flex;flex-wrap:wrap;gap:6px}.modal-meta__name-row{display:flex;gap:8px}.modal-meta__name-input{flex:1;min-width:0;background:var(--surface-sunken);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;transition:border-color .15s,box-shadow .15s}.modal-meta__name-input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.modal-meta__move-button,.modal-meta__delete-button{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius-sm);font-size:1rem;transition:border-color .15s,color .15s,background .15s}.modal-meta__move-button:hover{border-color:var(--border-strong);background:var(--surface-2)}.modal-meta__delete-button:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-soft)}.modal-close,.modal-nav,.modal-fullscreen,.modal-edit-toggle{position:fixed;background:#14161c8c;color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:50%;width:44px;height:44px;font-size:1.3rem;display:flex;align-items:center;justify-content:center;z-index:10;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .15s,transform .1s}.modal-close:hover,.modal-nav:hover,.modal-fullscreen:hover,.modal-edit-toggle:hover{background:#14161cd9}.modal-nav:active{transform:translateY(-50%) scale(.94)}.modal-close{top:18px;right:18px}.modal-fullscreen{top:18px;right:72px;font-size:1.1rem}.modal-edit-toggle{top:18px;right:126px;font-size:1.1rem}.modal-edit-toggle--active{background:var(--accent);border-color:transparent}.modal-edit-toggle--active:hover{background:var(--accent-hover)}.modal-nav--prev{left:18px;top:50%;transform:translateY(-50%)}.modal-nav--next{right:18px;top:50%;transform:translateY(-50%)}.modal-zoom-controls{position:fixed;bottom:26px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:#14161c99;border:1px solid rgba(255,255,255,.12);padding:7px 16px;border-radius:var(--radius-pill);z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.modal-zoom-controls button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;width:28px;height:28px;border-radius:50%;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .12s}.modal-zoom-controls button:hover:not(:disabled){background:#ffffff29}.modal-zoom-controls button:disabled{opacity:.4}.modal-zoom-controls__level{color:#fff;font-size:.8rem;min-width:40px;text-align:center}@media (max-width: 700px){.modal-content:not(.modal-content--form){width:92vw}.modal-media{width:100%;height:55vh;flex-shrink:0}.modal-meta{flex:1;min-height:0;overflow-y:auto}.modal-close,.modal-nav,.modal-fullscreen,.modal-edit-toggle{width:38px;height:38px;font-size:1.1rem}.modal-fullscreen,.modal-edit-toggle{font-size:.95rem}.modal-close{top:8px;right:8px}.modal-fullscreen{top:8px;right:52px}.modal-edit-toggle{top:8px;right:96px}.modal-nav--prev{left:6px}.modal-nav--next{right:6px}.modal-zoom-controls{bottom:12px}}.tag-editor__current{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.tag-editor__input-row{display:flex;gap:8px}.tag-editor__input-row input{flex:1;min-width:0;background:var(--surface-sunken);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s}.tag-editor__input-row input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.tag-editor__input-row button{background:var(--accent);border:none;color:#fff;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;transition:background .15s}.tag-editor__input-row button:hover{background:var(--accent-hover)}.tag-chip--suggestion{background:transparent;border:1px dashed var(--border-strong);color:var(--text-dim)}.tag-chip--suggestion:hover{border-style:solid;border-color:var(--accent);color:var(--accent)}.upload-button{position:relative;display:inline-flex;align-items:center;gap:8px}.upload-button button{background:var(--accent);border:none;color:#fff;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;box-shadow:var(--shadow-sm);transition:background .15s,transform .1s}.upload-button button:hover{background:var(--accent-hover)}.upload-button button:active{transform:translateY(1px)}.upload-progress{position:absolute;top:116%;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;min-width:230px;box-shadow:var(--shadow-lg);z-index:25}.upload-error{position:absolute;top:116%;right:0;background:var(--surface);border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius);padding:10px 14px;max-width:320px;font-size:.85rem;box-shadow:var(--shadow-lg);z-index:25}.inline-error{margin:0 22px 12px;padding:10px 14px;border:1px solid var(--danger);background:var(--danger-soft);border-radius:var(--radius);color:var(--danger);font-size:.85rem}.upload-progress__row{display:flex;flex-direction:column;gap:3px;margin-bottom:8px;font-size:.8rem}.upload-progress__row:last-child{margin-bottom:0}.upload-progress__row progress{width:100%;height:6px;border:none;border-radius:var(--radius-pill);overflow:hidden;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--surface-2)}.upload-progress__row progress::-webkit-progress-bar{background:var(--surface-2);border-radius:var(--radius-pill)}.upload-progress__row progress::-webkit-progress-value{background:var(--accent);border-radius:var(--radius-pill)}.upload-progress__row progress::-moz-progress-bar{background:var(--accent);border-radius:var(--radius-pill)}
