@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--page-bg:#f8e9e5;--page-bg-2:#f3c8bf;--primary:#c24d52;--heading-text:#4a242d;--body-text:#6f4450;--muted-text:#a26f7d;--panel-bg:#fff6f5db;--panel-border:#dfbac0;--display-font:"Fraunces", serif;--body-font:"Plus Jakarta Sans", sans-serif;font-family:var(--body-font);color:var(--body-text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:500;line-height:1.5}*{box-sizing:border-box}body{background:radial-gradient(circle at 16% 20%, #ffdede 0 14%, transparent 40%), radial-gradient(circle at 88% 11%, #ffc4b3 0 10%, transparent 34%), radial-gradient(circle at 52% 92%, #ffe5da 0 16%, transparent 38%), linear-gradient(145deg, var(--page-bg), var(--page-bg-2));min-height:100vh;margin:0}#root{min-height:100vh;padding-bottom:1rem}.app-shell{border:1px solid var(--panel-border);background:radial-gradient(circle at 12% -8%, #ffdcce8c, transparent 40%), radial-gradient(circle at 88% 4%, #ffc3b073, transparent 38%), var(--panel-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:28px;width:min(1120px,100% - 2rem);margin:1rem auto 2rem;padding:clamp(1rem,2.6vw,2rem);position:relative;overflow:hidden;box-shadow:0 22px 90px #36141829}.app-shell:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffb6a238,#0000 65%);border-radius:999px;width:340px;height:340px;position:absolute;top:-170px;right:-140px}.masthead{gap:.55rem;margin-bottom:1.3rem;animation:.6s both rise-in;display:grid}.logout-btn{width:fit-content;margin-top:.35rem}.eyebrow{text-transform:uppercase;letter-spacing:.22em;color:var(--muted-text);margin:0;font-size:.72rem}.masthead h1{font-family:var(--display-font);color:var(--heading-text);text-wrap:balance;margin:.55rem 0;font-size:clamp(2.1rem,5vw,4.1rem);line-height:.98}.subtitle{max-width:58ch;color:var(--body-text);margin:0;line-height:1.55}.error-banner{color:#8b3a1f;background:#fff2eb;border:1px solid #e2b3a0;border-radius:10px;margin-top:.7rem;padding:.7rem .85rem;font-size:.9rem}.dropzone{border:2px dashed var(--panel-border);background:linear-gradient(130deg,#fffcfbe0,#ffe4d5d1);border-radius:22px;gap:.95rem;margin:1.4rem 0;padding:clamp(1rem,2.5vw,1.6rem);transition:transform .25s,border-color .25s,box-shadow .25s;animation:.7s 80ms both rise-in;display:grid}.dropzone h2{color:var(--heading-text);margin:0;font-size:clamp(1.2rem,2.8vw,1.6rem)}.dropzone p{color:var(--body-text);margin:.25rem 0 0}.dropzone-active{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 14px 28px #c3614c2e}.actions-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}#photo-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.upload-btn,.danger-btn,.mode-switch button,.lightbox-meta button{font:600 .9rem/1 var(--body-font);cursor:pointer;border:1px solid #0000;border-radius:999px;padding:.6rem 1.05rem;transition:transform .2s,filter .2s,box-shadow .2s}.upload-btn{color:#fff;background:linear-gradient(120deg,#be4e3b,#da6f5a);box-shadow:0 10px 18px #be4e3b40}.danger-btn{color:#8d4e3e;background:#fff8f4;border-color:#d4b4a7}.danger-btn:disabled{opacity:.45;cursor:not-allowed}.counter-row{flex-wrap:wrap;gap:.8rem;display:flex}.counter-row span{letter-spacing:.04em;text-transform:uppercase;color:var(--muted-text);font-size:.82rem}.toolbar{grid-template-columns:1fr auto;gap:.9rem;margin:1rem 0 1.1rem;display:grid}.toolbar input,.card-body input{font:500 .93rem/1.1 var(--body-font);color:var(--heading-text);background:#fffdf9;border:1px solid #d8c6bf;border-radius:12px;padding:.66rem .85rem}.toolbar input:focus,.card-body input:focus{outline-offset:1px;outline:2px solid #c0582c42}.mode-switch{gap:.5rem;display:flex}.mode-switch button{color:#6f4432;background:#fff;border-color:#d8c6bf}.mode-switch .mode-active{color:#6f2f21;background:#ffd9cf;border-color:#f4b19b}.gallery{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.05rem;margin-top:1.2rem;display:grid}.empty-state{border:1px dashed var(--panel-border);text-align:center;color:var(--body-text);background:#ffffff7a;border-radius:16px;grid-column:1/-1;padding:2rem 1rem}.empty-state p{margin:0;font-size:1.05rem}.empty-state small{color:var(--muted-text);margin-top:.35rem;display:block}.empty-illustration{color:#cd6b74;justify-content:center;gap:.45rem;margin-bottom:.6rem;font-size:1.35rem;display:flex}.empty-illustration span{animation:2.8s ease-in-out infinite heart-float}.empty-illustration span:nth-child(2){color:#bf4f5e;font-size:1.65rem;animation-delay:.3s}.empty-illustration span:nth-child(3){animation-delay:.55s}@keyframes heart-float{0%,to{opacity:.84;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.card{animation:.55s cubic-bezier(.22,1,.36,1) both card-in;animation-delay:var(--card-delay,0s);background:linear-gradient(#fff,#fffaf8);border:1px solid #d8c6bf;border-radius:18px;transition:transform .25s,box-shadow .25s;overflow:hidden;box-shadow:0 14px 30px #57232b1f}.card:hover{transform:translateY(-3px);box-shadow:0 18px 34px #57232b29}@keyframes card-in{0%{opacity:0;transform:translateY(14px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.preview-btn{aspect-ratio:4/5;cursor:zoom-in;background:#000;border:none;width:100%;padding:0;display:block;overflow:hidden}.preview-btn img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.preview-btn:hover img{transform:scale(1.08)}.card-body{gap:.65rem;padding:.7rem;display:grid}.card-actions{gap:.5rem;display:flex}.card-actions button{font:600 .78rem/1 var(--body-font);color:#7a503f;cursor:pointer;background:#fffaf4;border:1px solid #dbcbc2;border-radius:999px;flex:1;padding:.45rem .55rem;transition:transform .18s,filter .18s}.card-actions button:hover{filter:brightness(.99);transform:translateY(-1px)}.card-actions .fav.is-fav{color:#8a3427;background:#ffd7cc;border-color:#f8bba9}.card-actions .trash{background:#fff}.lightbox{z-index:40;place-items:center;padding:1rem;animation:.25s fade-in;display:grid;position:fixed;inset:0}.backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#110803ba;border:none;animation:.24s fade-in;position:absolute;inset:0}.lightbox-content{background:#2b1411;border:1px solid #ffffff24;border-radius:20px;width:min(930px,100%);animation:.28s cubic-bezier(.22,1,.36,1) zoom-in;position:relative;overflow:hidden}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes zoom-in{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.lightbox-content img{object-fit:contain;background:#1d0c0a;width:100%;max-height:70vh;display:block}.lightbox-meta{color:#f9ede7;justify-content:space-between;align-items:center;gap:.8rem;padding:.8rem;display:flex}.lightbox-meta strong{font-weight:600}.lightbox-meta div{gap:.5rem;display:flex}.lightbox-meta button{color:#552f22;background:#fff}.upload-btn:hover,.danger-btn:hover,.mode-switch button:hover,.lightbox-meta button:hover{filter:brightness(1.03);transform:translateY(-1px)}.upload-btn:active,.danger-btn:active,.mode-switch button:active,.lightbox-meta button:active,.card-actions button:active{transform:translateY(0)}.upload-btn:focus-visible,.danger-btn:focus-visible,.mode-switch button:focus-visible,.lightbox-meta button:focus-visible,.card-actions button:focus-visible,.preview-btn:focus-visible{outline-offset:2px;outline:2px solid #c24d52a6}.login-view{width:min(560px,100% - 1rem)}.login-card{background:linear-gradient(#ffffffeb,#fff4eee6);border:1px solid #d8c6bf;border-radius:18px;gap:.55rem;padding:1rem;display:grid;box-shadow:0 16px 36px #57232b24}.login-card label{color:var(--heading-text);font-size:.86rem;font-weight:700}.login-card input{font:500 .93rem/1.1 var(--body-font);color:var(--heading-text);background:#fffdf9;border:1px solid #d8c6bf;border-radius:12px;padding:.7rem .85rem}.login-card input:focus{outline-offset:1px;outline:2px solid #c0582c42}.login-submit{width:fit-content;margin-top:.2rem}.hint-login{color:var(--muted-text)}@media (width<=740px){.app-shell{border-radius:20px;width:calc(100% - 1rem);margin:.5rem auto 1rem;padding:.85rem}.masthead h1{line-height:1.02}.logout-btn,.actions-row{width:100%}.actions-row>*{text-align:center;flex:1;justify-content:center}.toolbar{grid-template-columns:1fr}.mode-switch{justify-content:stretch}.mode-switch button{flex:1}.gallery{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.lightbox-meta{flex-direction:column;align-items:stretch}.lightbox-meta div{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.login-submit{width:100%}}@media (prefers-reduced-motion:reduce){.masthead,.dropzone,.card,.lightbox,.backdrop,.lightbox-content,.empty-illustration span{animation:none}.upload-btn,.danger-btn,.mode-switch button,.lightbox-meta button,.card-actions button,.card,.preview-btn img{transition:none}}
