*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-primary:#f97316;--clr-primary-dark:#ea580c;--clr-primary-light:#fed7aa;--clr-primary-100:#ffedd5;--clr-primary-50:#fff7ed;--clr-surface:#fff;--clr-background:#f5f5f5;--clr-outline:#e5e5e5;--clr-on-surface:#1c1b1f;--clr-on-surface-var:#737373;--clr-error:#b00020;--clr-error-bg:#fff1f0;--clr-warning:#f59e0b;--dp1:0 1px 3px #0000001f, 0 1px 2px #0000003d;--dp2:0 3px 6px #00000029, 0 3px 6px #0000003b;--dp4:0 6px 12px #0000002e, 0 4px 8px #0000001f;--dp8:0 14px 28px #00000026, 0 8px 10px #0000001a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:28px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}body{background:var(--clr-background);color:var(--clr-on-surface);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Roboto,system-ui,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}.app-content{flex:1}.app-bar{z-index:100;background:var(--clr-surface);height:64px;box-shadow:var(--dp1);align-items:center;gap:.5rem;padding:0 1.5rem;display:flex;position:sticky;top:0}.app-bar__title{color:var(--clr-on-surface-var);pointer-events:none;text-overflow:ellipsis;white-space:nowrap;max-width:50%;font-size:1.1rem;font-weight:500;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.app-bar__brand{color:var(--clr-primary);letter-spacing:-.5px;margin-right:auto;font-size:1.25rem;font-weight:700;text-decoration:none}.app-bar__brand:hover{color:var(--clr-primary-dark)}.app-bar__avatar{object-fit:cover;border:2px solid var(--clr-primary-100);border-radius:50%;width:32px;height:32px}.app-bar__name{color:var(--clr-on-surface-var);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.875rem;overflow:hidden}.notification-wrapper,.notification-bell{position:relative}.notification-badge{background:var(--clr-error);color:#fff;pointer-events:none;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.65rem;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notification-dropdown{background:var(--clr-surface);border-radius:var(--radius-md);width:340px;max-height:420px;box-shadow:var(--dp4);z-index:200;flex-direction:column;animation:.15s slide-up;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notification-dropdown__header{border-bottom:1px solid var(--clr-outline);padding:.75rem 1rem;font-size:.95rem;font-weight:500}.notification-dropdown__empty{text-align:center;color:var(--clr-on-surface-var);padding:2rem 1rem;font-size:.875rem}.notification-dropdown__list{max-height:360px;overflow-y:auto}.notification-item{text-align:left;cursor:pointer;width:100%;transition:background var(--transition);border:none;border-bottom:1px solid var(--clr-outline);background:0 0;align-items:flex-start;gap:.6rem;padding:.7rem 1rem;font-family:inherit;display:flex}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--clr-primary-50)}.notification-item--unseen{background:var(--clr-primary-100)}.notification-item--unseen:hover{background:var(--clr-primary-light)}.notification-item__icon{color:var(--clr-primary);flex-shrink:0;margin-top:2px;font-size:20px}.notification-item__body{flex-direction:column;gap:.15rem;min-width:0;display:flex}.notification-item__text{color:var(--clr-on-surface);font-size:.84rem;line-height:1.35}.notification-item__time{color:var(--clr-on-surface-var);font-size:.72rem}.reviewed-chip{color:#15803d;white-space:nowrap;vertical-align:middle;background:#dcfce7;border-radius:999px;align-items:center;gap:.2rem;margin-left:.4rem;padding:.1rem .55rem .1rem .35rem;font-size:.75rem;font-weight:500;line-height:1.4;display:inline-flex}.reviewed-chip .material-icons{color:#16a34a;font-size:14px}.btn{border-radius:var(--radius-xl);letter-spacing:.015em;cursor:pointer;height:40px;transition:background var(--transition), box-shadow var(--transition), opacity var(--transition);white-space:nowrap;border:none;align-items:center;gap:.35rem;padding:0 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn .material-icons{font-size:18px}.btn-contained{background:var(--clr-primary);color:#fff}.btn-contained:hover:not(:disabled){background:var(--clr-primary-dark);box-shadow:var(--dp1)}.btn-tonal{background:var(--clr-primary-100);color:var(--clr-primary-dark)}.btn-tonal:hover:not(:disabled){background:var(--clr-primary-light)}.btn-text{color:var(--clr-primary);background:0 0;padding:0 .75rem}.btn-text:hover:not(:disabled){background:#f9731614}.btn-outlined{color:var(--clr-on-surface-var);border:1px solid var(--clr-outline);background:0 0}.btn-outlined:hover:not(:disabled){background:var(--clr-primary-50);color:var(--clr-primary);border-color:var(--clr-primary-100)}.btn:disabled{opacity:.38;cursor:not-allowed}.icon-btn{width:36px;height:36px;color:var(--clr-on-surface-var);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:0;display:inline-flex}.icon-btn:hover:not(:disabled){color:var(--clr-on-surface);background:#00000012}.icon-btn:disabled{opacity:.38;cursor:not-allowed}.icon-btn .material-icons{font-size:20px}.icon-btn--danger:hover:not(:disabled){color:var(--clr-error);background:#fff1f0}.page-content{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.page-header h1{color:var(--clr-on-surface);font-size:1.5rem;font-weight:400}.library-count-hint{color:var(--clr-on-surface-var);margin-bottom:1.5rem;font-size:.82rem}.card-deck{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;display:grid}.library-card{background:var(--clr-surface);border-radius:var(--radius-md);box-shadow:var(--dp1);transition:box-shadow var(--transition), transform var(--transition);flex-direction:column;display:flex;overflow:hidden}.library-card:hover{box-shadow:var(--dp4);transform:translateY(-2px)}.library-card__media{background:linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-dark) 100%);flex-shrink:0;justify-content:center;align-items:center;height:160px;display:flex}.library-card__media .material-icons{color:#ffffffd9;font-size:72px}.library-card__body{color:inherit;flex:1;padding:1rem 1rem .25rem;text-decoration:none}.library-card__name{color:var(--clr-on-surface);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.2rem;font-size:1rem;font-weight:500;overflow:hidden}.library-card__meta{color:var(--clr-on-surface-var);font-size:.78rem}.library-card__actions{justify-content:flex-end;gap:.25rem;padding:.5rem .75rem .75rem;display:flex}.library-card__rename{align-items:center;gap:.35rem;padding:.75rem 1rem .5rem;display:flex}.library-card__rename input{border:1px solid var(--clr-outline);border-radius:var(--radius-sm);min-width:0;transition:border-color var(--transition);outline:none;flex:1;padding:.4rem .6rem;font-family:inherit;font-size:.9rem}.library-card__rename input:focus{border-color:var(--clr-primary)}.empty-state{color:var(--clr-on-surface-var);text-align:center;flex-direction:column;grid-column:1/-1;align-items:center;gap:.75rem;padding:5rem 1rem;display:flex}.empty-state .material-icons{opacity:.25;font-size:72px}.empty-state p{font-size:.95rem}.skeleton{background:linear-gradient(90deg, var(--clr-outline) 25%, #ebebeb 50%, var(--clr-outline) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200%}to{background-position:-200%}}.skeleton-card{border-radius:var(--radius-md);height:280px}.dialog-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:1rem;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.dialog{background:var(--clr-surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--dp8);flex-direction:column;gap:1.25rem;padding:1.5rem;animation:.15s slide-up;display:flex}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dialog h2{font-size:1.25rem;font-weight:500}.dialog__actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.share-dialog__url{border:1px solid var(--clr-outline);background:var(--clr-background);width:100%;color:var(--clr-on-surface);transition:border-color var(--transition);border-radius:.5rem;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.share-dialog__url:focus{border-color:var(--clr-primary)}.text-field{flex-direction:column;gap:.35rem;display:flex}.text-field label{color:var(--clr-on-surface-var);font-size:.8rem;font-weight:500}.text-field input{border:1px solid var(--clr-outline);border-radius:var(--radius-sm);width:100%;color:var(--clr-on-surface);background:var(--clr-surface);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:.65rem .9rem;font-family:inherit;font-size:.95rem}.text-field input:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px #f9731626}.text-field .field-error{color:var(--clr-error);font-size:.78rem}.alert{border-radius:var(--radius-sm);padding:.65rem .9rem;font-size:.875rem}.alert--error{background:var(--clr-error-bg);color:var(--clr-error);border:1px solid #ffccc7}.account-layout{flex-direction:column;gap:1.5rem;max-width:520px;display:flex}.account-card{background:var(--clr-surface);border-radius:var(--radius-md);box-shadow:var(--dp1);overflow:hidden}.account-card__header{background:linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-dark) 100%);color:#fff;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1.5rem 1.75rem;display:flex}.account-avatar{object-fit:cover;border:3px solid #ffffff80;border-radius:50%;width:88px;height:88px}.account-avatar-placeholder{background:#fff3;border:3px solid #fff6;border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;display:flex}.account-avatar-placeholder .material-icons{color:#fff;font-size:52px}.account-card__name{text-align:center;font-size:1.25rem;font-weight:500}.account-card__email{opacity:.85;text-align:center;font-size:.875rem}.account-card__body{padding:.25rem 1.5rem 1.25rem}.info-row{border-bottom:1px solid var(--clr-outline);align-items:center;gap:1rem;padding:.7rem 0;font-size:.9rem;display:flex}.info-row:last-child{border-bottom:none}.info-row__label{width:110px;color:var(--clr-on-surface-var);flex-shrink:0;font-size:.8rem}.chip{background:var(--clr-primary-100);color:var(--clr-primary-dark);border-radius:999px;align-items:center;padding:.15rem .65rem;font-size:.78rem;font-weight:500;display:inline-flex}.progress-section{border-top:1px solid var(--clr-outline);padding:1rem 1.5rem 1.5rem}.progress-header{justify-content:space-between;align-items:baseline;margin-bottom:.6rem;display:flex}.progress-header__label{color:var(--clr-on-surface);font-size:.85rem;font-weight:500}.progress-header__count{color:var(--clr-on-surface-var);font-size:.82rem}.progress-track{background:var(--clr-outline);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--clr-primary);border-radius:4px;min-width:4px;height:100%;transition:width .5s}.progress-fill--warning{background:var(--clr-warning)}.progress-fill--full{background:var(--clr-error)}.progress-caption{color:var(--clr-on-surface-var);margin-top:.4rem;font-size:.78rem}.login-page{background:var(--clr-primary-50);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-box{background:var(--clr-surface);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--dp4);flex-direction:column;align-items:center;gap:1.25rem;padding:2.5rem 2rem;display:flex}.login-box h2{color:var(--clr-primary);letter-spacing:-.5px;font-size:1.75rem;font-weight:700}.btn-google{background:var(--clr-surface);width:100%;color:var(--clr-on-surface);border:1px solid var(--clr-outline);border-radius:var(--radius-xl);cursor:pointer;height:44px;transition:background var(--transition), box-shadow var(--transition);justify-content:center;align-items:center;gap:.5rem;font-family:inherit;font-size:.9rem;font-weight:500;display:flex}.btn-google:hover{background:var(--clr-primary-50);box-shadow:var(--dp1)}.divider{text-align:center;width:100%;color:var(--clr-on-surface-var);font-size:.8rem;position:relative}.divider:before,.divider:after{content:"";background:var(--clr-outline);width:40%;height:1px;position:absolute;top:50%}.divider:before{left:0}.divider:after{right:0}.flash{background:var(--clr-error-bg);width:100%;color:var(--clr-error);border-radius:var(--radius-sm);border:1px solid #ffccc7;padding:.6rem .75rem;font-size:.85rem}.login-pending{text-align:center;color:var(--clr-on-surface-var);font-size:.9rem}.footer{text-align:center;color:var(--clr-on-surface-var);flex-shrink:0;padding:1.5rem 1rem;font-size:.8rem}.footer .text-muted{opacity:.6}.google-btn-wrapper{justify-content:center;display:flex}.library-card__media{cursor:pointer;text-decoration:none}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem;display:grid}.photo-tile{border-radius:var(--radius-md);background:var(--clr-surface);box-shadow:var(--dp1);aspect-ratio:1;flex-direction:column;display:flex;position:relative;overflow:hidden}.photo-tile--skeleton{aspect-ratio:1}.photo-tile__img{object-fit:cover;flex:1;width:100%;height:100%;min-height:0;display:block}.photo-tile__overlay{transition:background var(--transition);pointer-events:none;background:0 0;justify-content:flex-end;align-items:flex-start;padding:.5rem;display:flex;position:absolute;inset:0}.photo-tile__overlay>*{pointer-events:auto}.photo-tile:hover .photo-tile__overlay{background:#00000040}.photo-tile__delete{opacity:0;transition:opacity var(--transition);background:#ffffffe6!important}.photo-tile:hover .photo-tile__delete{opacity:1}.photo-tile__confirm{border-radius:var(--radius-sm);background:#ffffffeb;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.8rem;font-weight:500;display:flex}.photo-tile__like{width:36px;height:36px;color:var(--clr-on-surface-var);cursor:pointer;transition:background var(--transition), color var(--transition), transform var(--transition);z-index:2;opacity:0;background:#ffffffd9;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex;position:absolute;bottom:.5rem;right:.5rem}.photo-tile__like .material-icons{font-size:20px}.photo-tile:hover .photo-tile__like,.photo-tile__like--active{opacity:1}.photo-tile__like--active{color:var(--clr-error)}@media (hover:none),(pointer:coarse){.photo-tile__like{opacity:1}}.photo-tile__like:hover:not(:disabled){background:#fffffff2;transform:scale(1.15)}.photo-tile__liked-badge{width:28px;height:28px;color:var(--clr-error);z-index:2;pointer-events:none;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:.5rem;left:.5rem}.photo-tile__liked-badge .material-icons{font-size:16px}.app-bar__like-count{color:var(--clr-on-surface-var);align-items:center;gap:.3rem;font-size:.875rem;font-weight:500;display:flex}.photo-tile__meta{color:#ffffffd9;white-space:nowrap;text-overflow:ellipsis;opacity:0;transition:opacity var(--transition);background:#0000008c;padding:.2rem .5rem;font-size:.72rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.photo-tile:hover .photo-tile__meta{opacity:1}.lightbox{z-index:1000;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox__pair{align-items:center;gap:1.5rem;max-width:95vw;max-height:90vh;display:flex}.lightbox__side{flex-direction:column;flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.lightbox__label{color:#fffc;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.875rem}.lightbox__img{object-fit:contain;cursor:default;border-radius:var(--radius-md);max-width:45vw;max-height:85vh}.lightbox__content{justify-content:center;align-items:center;display:flex}.lightbox__content .lightbox__img{max-width:95vw;max-height:95vh}@media (width<=600px){.lightbox__content .lightbox__img{border-radius:0;max-width:100vw;max-height:100vh}}.lightbox__close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:2rem;position:absolute;top:1rem;right:1rem}.drop-zone{border:2px dashed var(--clr-outline);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition), background var(--transition);text-align:center;color:var(--clr-on-surface-var);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;margin-top:1rem;padding:4rem 2rem;display:flex}.drop-zone:hover,.drop-zone--active{border-color:var(--clr-primary);background:var(--clr-primary-50);color:var(--clr-primary-dark)}.drop-zone--compact{border-radius:var(--radius-md);flex-direction:row;gap:.5rem;margin-bottom:.5rem;padding:1.25rem 1rem}.drop-zone__icon{opacity:.4;font-size:48px}.drop-zone--compact .drop-zone__icon{opacity:.6;font-size:24px}.drop-zone__title{font-size:1.1rem;font-weight:500}.drop-zone__hint{opacity:.75;font-size:.85rem}.upload-queue{flex-direction:column;gap:.4rem;margin-bottom:.75rem;display:flex}.upload-item{background:var(--clr-surface);border-radius:var(--radius-sm);box-shadow:var(--dp1);align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.85rem;display:flex}.upload-item__icon{flex-shrink:0;font-size:18px}.upload-item--uploading .upload-item__icon{color:var(--clr-primary)}.upload-item--error .upload-item__icon{color:var(--clr-error)}.upload-item--pending .upload-item__icon{color:var(--clr-on-surface-var)}.upload-item__name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.upload-item__error{color:var(--clr-error);flex-shrink:0;font-size:.78rem}
