.header{background:linear-gradient(135deg,#d24a70,#c74570);box-shadow:0 4px 12px #d24a7033;padding:15px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.logo{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0;text-shadow:0 2px 4px #0000001a}.header-nav{align-items:center;display:flex}.user-info{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#fff3;border-radius:30px;margin-right:20px;padding:5px 15px}.user-avatar{border:2px solid #fff;height:36px;margin-right:10px;width:36px}.user-name{color:#fff}.login-button,.logout-button{background:#ffffffe6;border:none;border-radius:30px;box-shadow:0 2px 5px #0000001a;color:#d24a70;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.login-button:hover,.logout-button:hover{background-color:#fff;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}@media (max-width:768px){.header-content{flex-direction:column;gap:15px}.logo{font-size:20px}.user-info{margin-right:0}}.footer{background:linear-gradient(135deg,#d24a70,#c74570);box-shadow:0 -5px 15px #d24a701a;color:#fff;margin-top:auto;padding:30px 20px}.footer-content{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:1200px}.footer-content p{font-size:16px;font-weight:500;margin:0 0 15px}.footer-links{display:flex;gap:20px}.footer-links a{color:#fff;font-weight:500;padding:5px 0;position:relative;text-decoration:none;transition:all .3s ease}.footer-links a:after{background-color:#fff;bottom:0;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.footer-links a:hover:after{width:100%}@media (max-width:768px){.footer-links{align-items:center;flex-direction:column;gap:10px}}.google-login-button{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:500;justify-content:center;padding:14px;transition:all .3s ease;width:100%}.google-login-button:hover{background-color:#f9f9f9;border-color:#d24a70;box-shadow:0 2px 8px #d24a701a}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{animation:modalFadeIn .3s ease;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #00000026;max-width:450px;overflow:hidden;width:90%}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;background:linear-gradient(135deg,#f9f0f4,#f5e6ec);border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h2{color:#333;font-size:22px;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;transition:all .2s ease;width:30px}.close-button:hover{background-color:#d24a701a;color:#d24a70}.modal-content{padding:25px;text-align:center}.modal-content p{color:#666;font-size:16px;margin-bottom:20px}.google-register-button{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:500;justify-content:center;padding:14px;transition:all .3s ease;width:100%}.google-register-button:hover{background-color:#f9f9f9;border-color:#d24a70;box-shadow:0 2px 8px #d24a701a}.google-icon{align-items:center;color:#4285f4;display:flex;font-weight:700;height:20px;justify-content:center;margin-right:12px;width:20px}.app{background-color:#f9f9f9;display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}.auth-container{align-items:center;background:linear-gradient(135deg,#f9f0f4,#f5e6ec);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.auth-container:before{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="0 0 100 100"><rect width="100" height="100" fill="none"/><circle cx="50" cy="50" r="40" stroke="rgba%28210, 74, 112, 0.05%29" stroke-width="1" fill="none"/></svg>');background-size:100px 100px;bottom:0;content:"";left:0;opacity:.5;position:absolute;right:0;top:0;z-index:0}.auth-card{animation:fadeInUp .6s ease-out;background:#fff;border:1px solid #d24a701a;border-radius:16px;box-shadow:0 10px 30px #d24a7026;max-width:450px;overflow:hidden;padding:40px;position:relative;text-align:center;width:100%;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-logo{border-radius:50%;box-shadow:0 4px 12px #d24a7033;height:80px;margin-bottom:20px;object-fit:cover;width:80px}.auth-card h1{color:#333;font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:10px}.auth-card p{color:#666;font-size:16px;line-height:1.5;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:350px}.login-button{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;margin-bottom:15px;padding:14px;transition:all .3s ease;width:100%}.login-button:hover{border-color:#d24a70;box-shadow:0 4px 12px #d24a7026;transform:translateY(-2px)}.login-button svg{flex-shrink:0}.register-button{background:linear-gradient(135deg,#d24a70,#c74570);border:none;border-radius:8px;box-shadow:0 4px 10px #d24a7033;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:all .3s ease;width:100%}.register-button:hover{box-shadow:0 6px 15px #d24a704d;transform:translateY(-2px)}.loading-container{align-items:center;background-color:#f9f9f9;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #d24a70;border-radius:50%;border-top-color:#fff;height:40px;margin-bottom:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.portal-header{background:linear-gradient(135deg,#f9f0f4,#f5e6ec);border-bottom:1px solid #f0f0f0;display:flex;flex-direction:column;padding:30px}.header-left{margin-bottom:15px}.header-right{align-items:center;display:flex;justify-content:space-between}.portal-header h1{color:#333;font-size:28px;font-weight:700;margin-bottom:8px}.portal-header p{color:#666;font-size:16px;margin:0}.user-info{align-items:center;display:flex;gap:10px}.user-avatar{border-radius:50%;height:40px;object-fit:cover;width:40px}.user-name{color:#333;font-weight:500}.logout-button{background:none;border:1px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;padding:6px 12px;transition:all .3s ease}.logout-button:hover{border-color:#d24a70;color:#d24a70}.header-stats{display:flex;gap:20px;margin-top:15px}.stat-item{color:#666;font-size:14px}.memories-controls{background-color:#fff;border-bottom:1px solid #f0f0f0;flex-wrap:wrap;gap:15px;justify-content:space-between;padding:20px 30px}.controls-left,.memories-controls{align-items:center;display:flex}.controls-right{display:flex;gap:10px}.search-box{align-items:center;display:flex;position:relative}.search-icon{color:#999;left:15px;position:absolute}.search-input{border:1px solid #e0e0e0;border-radius:8px;font-size:14px;padding:10px 15px 10px 40px;transition:all .3s ease;width:250px}.search-input:focus{border-color:#d24a70;box-shadow:0 0 0 3px #d24a701a;outline:none}.clear-search{background:none;border:none;color:#999;cursor:pointer;font-size:14px;position:absolute;right:10px;transition:color .2s ease}.clear-search:hover{color:#d24a70}.filter-select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;padding:8px 12px;transition:all .3s ease}.filter-select:focus{border-color:#d24a70;box-shadow:0 0 0 3px #d24a701a;outline:none}.no-results{align-items:center;display:flex;flex-direction:column;padding:40px;text-align:center}.no-results-icon{color:#d24a70;font-size:48px;margin-bottom:15px}.no-results h3{color:#333;font-size:20px;margin-bottom:10px}.no-results p{color:#666;margin-bottom:20px}.reset-filters-btn{background:linear-gradient(135deg,#d24a70,#c74570);border:none;border-radius:8px;box-shadow:0 2px 5px #d24a7033;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.reset-filters-btn:hover{box-shadow:0 4px 8px #d24a704d;transform:translateY(-2px)}.timeline-container{flex:1 1;padding:30px}.timeline{margin:0 auto;max-width:1200px}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{color:#d24a70;font-size:64px;margin-bottom:20px}.empty-state h3{color:#333;font-size:24px;margin-bottom:10px}.empty-state p{color:#666;font-size:16px;max-width:500px}@media (max-width:768px){.auth-card{padding:30px 20px}.auth-card h1{font-size:24px}.auth-card p{font-size:14px}.login-button,.register-button{font-size:14px;padding:12px}.memories-controls{align-items:stretch;flex-direction:column}.controls-left,.controls-right{justify-content:center}.search-input{width:100%}.header-stats{flex-wrap:wrap;gap:10px}.timeline-container{padding:20px 15px}}.memory-card{background-color:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 8px #0000000d;cursor:pointer;margin-bottom:24px;overflow:hidden;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.memory-card:hover{border-color:#d24a70;box-shadow:0 12px 24px #d24a7026;transform:translateY(-4px)}.memory-card.expanded{border-color:#d24a70;box-shadow:0 8px 20px #d24a701f}.card-glow{background:radial-gradient(circle at center,#d24a700d 0,#fff0 70%);height:100%;left:0;opacity:0;pointer-events:none;position:absolute;top:0;transition:opacity .3s ease;width:100%}.memory-card.hovered .card-glow{opacity:1}.card-actions{display:flex;gap:10px;opacity:0;position:absolute;right:20px;top:20px;transition:opacity .3s ease}.memory-card:hover .card-actions{opacity:1}.delete-btn,.share-btn{align-items:center;background-color:#fff;border:1px solid #f0f0f0;border-radius:50%;box-shadow:0 2px 5px #0000000d;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.share-btn:hover{border-color:#d24a70;color:#d24a70;transform:scale(1.1)}.delete-btn:hover{border-color:#e53e3e;color:#e53e3e;transform:scale(1.1)}.card-header{justify-content:space-between;margin-bottom:20px}.card-header,.year-badge{align-items:center;display:flex}.year-badge{background:linear-gradient(135deg,#f9f0f4,#f5e6ec);border-radius:20px;box-shadow:0 2px 5px #d24a701a;color:#333;font-size:14px;font-weight:600;gap:8px;padding:8px 16px}.year-icon{color:#d24a70}.mood-indicator{color:#666;font-size:14px;font-style:italic}.color-palette-section{margin-bottom:24px}.color-palette-section h4{color:#333;font-size:16px;font-weight:600;margin-bottom:12px}.color-palette{display:flex;flex-wrap:wrap;gap:12px}.color-item{align-items:center;background-color:#f9f9f9;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:6px 10px;transition:all .2s ease}.color-item:hover{background-color:#f5f5f5;box-shadow:0 2px 5px #0000000d;transform:translateY(-2px)}.color-bubble{border:1px solid #f0f0f0;border-radius:50%;box-shadow:0 1px 3px #0000001a;height:18px;width:18px}.color-code{color:#666;font-family:monospace;font-size:12px}.tags-section{margin-bottom:20px}.tags-section h4{color:#333;font-size:16px;font-weight:600;margin-bottom:12px}.tags{display:flex;flex-wrap:wrap;gap:10px}.tag{background:linear-gradient(135deg,#f9f0f4,#f5e6ec);border-radius:16px;box-shadow:0 1px 3px #d24a701a;color:#333;font-size:13px;font-weight:500;padding:6px 12px}.card-details{border-top:1px solid #f0f0f0;margin-top:24px;padding-top:20px}.detail-item{display:flex;font-size:14px;margin-bottom:12px}.detail-label{align-items:center;color:#666;display:flex;font-weight:500;gap:8px;width:140px}.detail-value{color:#333;flex:1 1;word-break:break-word}.detail-value.monospace{background-color:#f9f9f9;border-radius:4px;font-family:monospace;font-size:12px;padding:2px 6px}.card-footer{margin-top:20px;text-align:center}.expand-hint{color:#999;font-size:13px;font-style:italic}@media (max-width:768px){.memory-card{padding:20px}.card-header{align-items:flex-start;gap:12px}.card-header,.detail-item{flex-direction:column}.detail-label{margin-bottom:6px;width:auto}}.upload-section{margin-bottom:40px}.upload-box{background-color:#fff;border:2px dashed #d24a70;border-radius:16px;box-shadow:0 2px 10px #d24a700d;overflow:hidden;padding:50px;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.upload-box.dragging{background-color:#d24a700d;border-color:#d24a70;transform:scale(1.02)}.upload-box.uploading{border-color:#d24a70;border-style:solid;box-shadow:0 5px 15px #d24a701a}.upload-box.has-preview{border:1px solid #d24a70;padding:0}.upload-content{position:relative;z-index:2}.upload-icon{color:#d24a70;font-size:56px;margin-bottom:24px}.upload-box h3{color:#333;font-size:22px;font-weight:600;margin-bottom:12px}.upload-box p{color:#666;font-size:16px;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:450px}.login-btn{background:linear-gradient(135deg,#d24a70,#c74570);border:none;border-radius:8px;box-shadow:0 4px 10px #d24a7033;color:#fff;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s ease}.login-btn:hover{box-shadow:0 6px 15px #d24a704d;transform:translateY(-2px)}.upload-btn{background:linear-gradient(135deg,#d24a70,#c74570);border:none;border-radius:8px;box-shadow:0 4px 10px #d24a7033;color:#fff;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s ease}.upload-btn:hover{box-shadow:0 6px 15px #d24a704d;transform:translateY(-2px)}.upload-hint{color:#999;font-size:14px;margin-top:15px}.upload-progress{margin-top:24px}.progress-bar{background-color:#f0f0f0;border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#d24a70,#c74570);height:100%;transition:width .3s ease}.progress-text{color:#666}.progress-text,.upload-status{font-size:14px;font-weight:500}.upload-status{align-items:center;border-radius:8px;display:flex;gap:10px;justify-content:center;margin-top:24px;padding:14px}.upload-status.success{background-color:#48bb781a;border:1px solid #48bb7833;color:#22543d}.upload-status.error{background-color:#f565651a;border:1px solid #f5656533;color:#742a2a}.upload-status.info{background-color:#4299e11a;border:1px solid #4299e133;color:#2c5282}.status-icon{font-size:20px}.preview-container{border-radius:16px 16px 0 0;height:350px;overflow:hidden;position:relative;width:100%}.preview-image{height:100%;object-fit:cover;width:100%}.preview-overlay{background:linear-gradient(0deg,#000000b3,#0000);bottom:0;color:#fff;left:0;padding:25px;position:absolute;right:0}.preview-filename{font-size:18px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-effects{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.effect-pulse{background:radial-gradient(circle,#d24a7033 0,#fff0 70%);border-radius:50%;height:300px;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);width:300px}.effect-pulse.delay-1{animation:pulse 3s .5s infinite}.effect-pulse.delay-2{animation:pulse 3s 1s infinite}@keyframes pulse{0%{opacity:.8;transform:translate(-50%,-50%) scale(.1)}to{opacity:0;transform:translate(-50%,-50%) scale(1)}}@media (max-width:768px){.upload-box{padding:40px 25px}.upload-icon{font-size:42px}.upload-box h3{font-size:18px}.upload-box p{font-size:14px}.login-btn,.upload-btn{font-size:14px;padding:12px 24px}}
/*# sourceMappingURL=main.2cb8e962.css.map*/