:root{--bg: #fff5f9;--bg-warm: #fce8f0;--surface: #fffbfd;--text: #4a3540;--text-soft: #8a6b7a;--accent: #f5a8c4;--accent-deep: #e889ad;--accent-soft: #fdd9e8;--border: #f5d0e0;--shadow: 0 12px 40px rgba(232, 137, 173, .12);--radius: 16px;--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-weight:400;color:var(--text);background:radial-gradient(circle at top,rgba(253,217,232,.5),transparent 30%),var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.2;margin:0}button,input,textarea{font-family:inherit}.page{min-height:100vh;padding:2rem 1.25rem}.login-page{display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 60% at 50% 0%,var(--accent-soft) 0%,transparent 70%),var(--bg)}.login-card{width:100%;max-width:420px;padding:2.5rem 2rem;background:#ffffffd1;border:1px solid var(--border);border-radius:28px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 14px 36px #e889ad24,0 4px 12px #e889ad14;transition:transform .25s ease,box-shadow .25s ease}.login-card:hover{transform:translateY(-2px);box-shadow:0 18px 42px #e889ad2e,0 8px 18px #e889ad14}.login-header{text-align:center;margin-bottom:2rem}.login-icon{display:inline-block;font-size:2rem;color:var(--accent);margin-bottom:.5rem}.login-header h1{font-size:2.25rem;color:var(--accent-deep)}.login-subtitle{margin:.75rem 0 0;font-size:.95rem;color:var(--text-soft);font-weight:300}.login-form{display:flex;flex-direction:column;gap:.35rem}.login-form label{font-size:.8rem;font-weight:500;color:var(--text-soft);margin-top:.75rem}.login-form input{padding:.85rem 1rem;border:1px solid var(--border);border-radius:14px;background:#fffc;font-size:1rem;color:var(--text);transition:all .25s ease}.login-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px #f5a8c438}.form-error{margin:.75rem 0 0;font-size:.875rem;color:#b54a4a}.login-hint{margin:1.5rem 0 0;text-align:center;font-size:.75rem;color:var(--text-soft)}.btn-primary{margin-top:1.25rem;padding:.9rem 1.5rem;border:none;border-radius:14px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 10px 28px #e889ad59}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{padding:.5rem 1rem;border:1px solid var(--border);border-radius:12px;background:#fff9;color:var(--text-soft);font-size:.875rem;cursor:pointer;transition:all .25s ease}.btn-ghost:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent);color:var(--accent-deep);transform:translateY(-1px)}.loading-content{display:inline-flex;align-items:center;gap:.65rem}.loading-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite}.loading-spinner.large{width:34px;height:34px;border-width:3px;border-color:#e889ad2e;border-top-color:var(--accent-deep)}.loading-state{padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-soft);text-align:center}@keyframes spin{to{transform:rotate(360deg)}}.journal-page{max-width:1100px;margin:0 auto}.journal-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.journal-header h1{font-size:clamp(1.75rem,4vw,2.8rem);color:var(--accent-deep)}.journal-tagline{margin:.5rem 0 0;max-width:36rem;font-size:.95rem;font-weight:300;color:var(--text-soft)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.memories-hub{margin-bottom:2.5rem}.page-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.page-tabs .tab{padding:.65rem 1.15rem;border:1px solid var(--border);border-radius:999px;background:#fffc;color:var(--text-soft);font-size:.9rem;cursor:pointer;transition:all .25s ease;display:inline-flex;align-items:center;gap:.4rem}.page-tabs .tab:hover:not(.active){transform:translateY(-2px);background:var(--accent-soft)}.page-tabs .tab.active{background:linear-gradient(135deg,var(--accent-soft) 0%,#fce0ec 100%);border-color:var(--accent);color:var(--accent-deep);font-weight:500;box-shadow:0 8px 20px #e889ad2e}.tab-badge{font-size:.75rem;background:var(--accent);color:#fff;padding:.15rem .55rem;border-radius:999px;font-weight:700;box-shadow:0 6px 16px #e889ad40}.mel-card{position:relative;background:linear-gradient(180deg,#fffffff0,#fff8fcfa);border:1px solid rgba(245,208,224,.9);border-radius:28px;padding:1.9rem;box-shadow:0 14px 38px #e889ad1f,0 4px 12px #e889ad0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;transition:all .28s ease}.mel-card:hover{transform:translateY(-2px);box-shadow:0 20px 46px #e889ad29,0 8px 18px #e889ad14}.mel-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(255,255,255,.55),transparent 35%);pointer-events:none}.mel-card>h2{font-size:1.7rem;margin:0 0 .5rem;color:var(--accent-deep)}.mel-card-intro{margin:0 0 1.5rem;font-size:.92rem;color:var(--text-soft);font-weight:300}.memory-form{display:flex;flex-direction:column;gap:.45rem}.memory-form label{font-size:.82rem;font-weight:600;color:var(--text-soft);margin-top:.5rem}.memory-form input,.memory-form textarea{padding:.85rem 1rem;border:1px solid var(--border);border-radius:16px;background:#ffffffd1;font-size:.96rem;color:var(--text);resize:vertical;transition:all .25s ease}.memory-form input:focus,.memory-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px #f5a8c438}.file-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;margin-top:1.25rem}.file-preview-card{overflow:hidden;border-radius:22px;background:linear-gradient(180deg,#fffffff2,#fff5f9eb);border:1px solid rgba(245,208,224,.75);box-shadow:0 10px 24px #e889ad1a;transition:all .25s ease}.file-preview-card:hover{transform:translateY(-4px);box-shadow:0 18px 34px #e889ad29}.file-preview-image,.file-preview-video{width:100%;height:180px;object-fit:cover;display:block}.file-preview-footer{padding:.85rem}.file-preview-name{font-size:.82rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{font-size:.75rem;color:var(--text-soft);margin-top:.2rem}.entry-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.entry-card{position:relative;background:linear-gradient(180deg,#fffafd,#fff5f9);border-radius:24px;border:1px solid rgba(245,208,224,.8);overflow:hidden;box-shadow:0 8px 20px #e889ad14,0 2px 8px #e889ad0a;transition:all .25s ease;animation:fadeSoft .35s ease}@keyframes fadeSoft{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.entry-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(255,255,255,.45),transparent 35%);pointer-events:none}.entry-card:hover{transform:translateY(-3px);border-color:#f5a8c4e6;box-shadow:0 16px 36px #e889ad24,0 6px 14px #e889ad14}.entry-card.is-open{border-color:var(--accent);box-shadow:0 0 0 3px #f5a8c42e,0 16px 36px #e889ad24}.entry-card-toggle{width:100%;padding:1.35rem;border:none;background:transparent;text-align:left;cursor:pointer;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;transition:background .25s ease}.entry-card-toggle:hover{background:linear-gradient(90deg,#fdd9e88c,#fff5f9d9)}.entry-card-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.5rem;flex:1;min-width:0}.entry-card h3{font-size:1.2rem;color:var(--text)}.entry-card time{font-size:.8rem;color:var(--text-soft)}.entry-toggle-label{font-size:.82rem;font-weight:600;color:var(--accent-deep);white-space:nowrap}.entry-attach-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:.45rem;min-width:24px;padding:.18rem .55rem;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff;font-size:.72rem;font-weight:700;box-shadow:0 6px 16px #e889ad40}.entry-card-content{padding:0 1.35rem 1.35rem;border-top:1px solid rgba(245,208,224,.7)}.entry-body{margin:0 0 1rem;font-size:.96rem;white-space:pre-wrap;color:var(--text);line-height:1.7}.entry-media-grid{list-style:none;margin:0;padding:0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.entry-media-item{border-radius:20px;overflow:hidden;border:1px solid rgba(245,208,224,.7);background:#fff;box-shadow:0 8px 20px #e889ad1a;transition:all .25s ease}.entry-media-item:hover{transform:scale(1.02);box-shadow:0 16px 30px #e889ad29}.entry-media-item img,.entry-media-item video{width:100%;display:block;max-height:280px;object-fit:contain}.save-feedback{display:inline-flex;align-items:center;gap:.45rem;padding:.75rem 1rem;border-radius:14px;background:linear-gradient(135deg,#dfffece6,#f0fff7f2);border:1px solid rgba(120,210,160,.35);color:#2f7a50;font-size:.9rem;font-weight:600;box-shadow:0 8px 18px #78d2a01a}.empty-state{margin:0;padding:2rem 1rem;text-align:center;font-size:.95rem;color:var(--text-soft);font-style:italic;background:#ffffffb3;border-radius:18px}.banner-warning{margin:0 0 1.5rem;padding:.85rem 1rem;background:#fff0f5;border:1px solid var(--border);border-radius:14px;color:var(--accent-deep);font-size:.9rem}@media(max-width:768px){.mel-card{padding:1.35rem}.entry-card-toggle{padding:1rem}.journal-header{flex-direction:column}.page{padding:1rem}.file-preview-grid{grid-template-columns:repeat(2,1fr)}.file-preview-image,.file-preview-video{height:150px}.save-feedback{width:100%;justify-content:center;text-align:center}}
