@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400&family=DM+Sans:wght@300;400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #faf8f4;--warm-50: #f5f1ea;--warm-100: #ede6d8;--warm-200: #d9cdb8;--warm-400: #a8926e;--warm-600: #7a6348;--dark: #1e1a14;--dark-60: #4a4236;--dark-40: #7a7060;--rose: #c9756a;--rose-light: #f0dbd8;--sage: #7a9e8a;--sage-light: #ddeee5;--sky: #6a8faf;--sky-light: #dce9f5;--gold: #c49a3c;--gold-light: #faefd4;--r: .5rem;--r-lg: 1rem;--shadow: 0 2px 16px rgba(30,26,20,.08);--shadow-lg: 0 8px 32px rgba(30,26,20,.12)}html,body,#root{height:100%;background:var(--cream);color:var(--dark)}body{font-family:DM Sans,sans-serif;font-size:15px;line-height:1.6}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;min-width:220px;background:var(--dark);display:flex;flex-direction:column;padding:2rem 1.25rem;gap:0}.sidebar-brand{display:flex;align-items:center;gap:.5rem;margin-bottom:2.5rem}.brand-heart{font-size:1.4rem;color:var(--rose)}.brand-text{font-family:Playfair Display,serif;font-size:1.4rem;color:#fff;letter-spacing:.02em}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;border-radius:var(--r);color:var(--warm-200);text-decoration:none;font-size:.875rem;font-weight:400;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:#c9756a2e;color:var(--rose);font-weight:500}.logout-btn{margin-top:1rem;padding:.6rem .9rem;background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--warm-200);border-radius:var(--r);cursor:pointer;font-size:.8rem;font-family:DM Sans,sans-serif;transition:background .15s}.logout-btn:hover{background:#ffffff12}.main-content{flex:1;overflow-y:auto;padding:2.5rem}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2rem}.page-title{font-family:Playfair Display,serif;font-size:2rem;font-weight:400;color:var(--dark)}.page-subtitle{color:var(--dark-40);font-size:.875rem;margin-top:.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--r);font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s}.btn-primary{background:var(--dark);color:#fff}.btn-primary:hover{background:var(--dark-60)}.btn-rose{background:var(--rose);color:#fff}.btn-rose:hover{opacity:.88}.btn-ghost{background:transparent;color:var(--dark-60);border:1px solid var(--warm-200)}.btn-ghost:hover{background:var(--warm-50)}.btn-sm{padding:.4rem .85rem;font-size:.8rem}.btn-icon{padding:.5rem;border-radius:var(--r);background:transparent;border:none;cursor:pointer;color:var(--dark-40);transition:all .15s}.btn-icon:hover{color:var(--dark);background:var(--warm-50)}.card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--warm-100);overflow:hidden}.card-body{padding:1.25rem}.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.grid-movies{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.tabs{display:flex;gap:.25rem;margin-bottom:1.75rem;border-bottom:1px solid var(--warm-100);padding-bottom:.5rem}.tab{padding:.45rem 1rem;border-radius:var(--r) var(--r) 0 0;border:none;background:transparent;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.875rem;color:var(--dark-40);transition:all .15s}.tab:hover{color:var(--dark)}.tab.active{color:var(--dark);font-weight:500;background:var(--warm-50)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:500}.badge-rose{background:var(--rose-light);color:var(--rose)}.badge-sage{background:var(--sage-light);color:var(--sage)}.badge-sky{background:var(--sky-light);color:var(--sky)}.badge-gold{background:var(--gold-light);color:var(--gold)}.badge-warm{background:var(--warm-100);color:var(--dark-60)}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-label{font-size:.8rem;font-weight:500;color:var(--dark-60);letter-spacing:.02em}.form-input,.form-select,.form-textarea{padding:.6rem .875rem;border:1px solid var(--warm-200);border-radius:var(--r);font-family:DM Sans,sans-serif;font-size:.875rem;color:var(--dark);background:#fff;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--warm-400);box-shadow:0 0 0 3px #a8926e1f}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1a1473;display:flex;align-items:center;justify-content:center;z-index:100;padding:1.5rem;animation:fadeIn .15s ease}.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-lg{max-width:760px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 0;margin-bottom:1.25rem}.modal-title{font-family:Playfair Display,serif;font-size:1.4rem}.modal-body{padding:0 1.5rem 1.5rem}.modal-footer{padding:1rem 1.5rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem;border-top:1px solid var(--warm-100)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.link-preview{border:1px solid var(--warm-100);border-radius:var(--r);overflow:hidden;display:flex;gap:0;margin-top:.75rem;text-decoration:none;color:inherit;transition:box-shadow .15s}.link-preview:hover{box-shadow:var(--shadow)}.link-preview-image{width:100px;min-width:100px;object-fit:cover}.link-preview-body{padding:.75rem;flex:1;min-width:0}.link-preview-title{font-weight:500;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-preview-desc{font-size:.775rem;color:var(--dark-40);margin-top:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.link-preview-favicon{display:flex;align-items:center;gap:.4rem;margin-top:.5rem}.link-preview-favicon img{width:14px;height:14px}.link-preview-favicon span{font-size:.725rem;color:var(--dark-40)}.stars{display:flex;gap:.2rem;cursor:pointer}.star{font-size:1.1rem;color:var(--warm-200);transition:color .1s}.star.filled{color:var(--gold)}.cal-list{display:flex;flex-direction:column;gap:.75rem}.cal-item{display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.25rem;background:#fff;border-radius:var(--r-lg);border:1px solid var(--warm-100)}.cal-date{min-width:48px;text-align:center}.cal-day{font-family:Playfair Display,serif;font-size:1.75rem;line-height:1;color:var(--dark)}.cal-month{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--dark-40)}.cal-divider{width:1px;background:var(--warm-100)}.cal-info{flex:1}.cal-title{font-weight:500;font-size:.95rem}.cal-meta{font-size:.8rem;color:var(--dark-40);margin-top:.2rem;display:flex;gap:.75rem;flex-wrap:wrap}.movie-card{cursor:pointer;transition:transform .18s,box-shadow .18s}.movie-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.movie-poster{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;background:var(--warm-100)}.movie-poster-placeholder{width:100%;aspect-ratio:2/3;background:var(--warm-100);display:flex;align-items:center;justify-content:center;color:var(--dark-40);font-size:2.5rem}.movie-info{padding:.6rem .75rem}.movie-title{font-size:.825rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movie-year{font-size:.75rem;color:var(--dark-40)}.movie-watched-badge{position:absolute;top:.5rem;right:.5rem;background:var(--sage);color:#fff;border-radius:99px;padding:.15rem .5rem;font-size:.7rem}.empty{text-align:center;padding:4rem 2rem;color:var(--dark-40)}.empty-icon{font-size:2.5rem;margin-bottom:1rem}.empty-text{font-size:1rem}.streaming-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.streaming-chip{display:flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:99px;font-size:.72rem;font-weight:500;background:var(--warm-100);color:var(--dark-60)}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.comment{background:var(--warm-50);border-radius:var(--r);padding:.6rem .875rem}.comment-author{font-size:.75rem;font-weight:500;color:var(--dark-60);margin-bottom:.25rem}.comment-text{font-size:.875rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--warm-200);border-radius:99px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.mt-sm{margin-top:.5rem}.mt-md{margin-top:1rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--dark-40)}.font-serif{font-family:Playfair Display,serif}.relative{position:relative}.divider{height:1px;background:var(--warm-100);margin:1.25rem 0}.chip-group{display:flex;flex-wrap:wrap;gap:.5rem}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--dark);border-top:1px solid rgba(255,255,255,.08);padding:.5rem 0 calc(.5rem + env(safe-area-inset-bottom));z-index:200}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;color:#fff6;text-decoration:none;font-size:.65rem;font-weight:500;letter-spacing:.02em;padding:.35rem .5rem;transition:color .15s}.bottom-nav-item:hover{color:#ffffffb3}.bottom-nav-item.active{color:var(--rose)}.bottom-nav-item svg{flex-shrink:0}@media (max-width: 768px){.sidebar{display:none}.bottom-nav{display:flex}.app-shell{flex-direction:column;height:100dvh}.main-content{padding:1.25rem 1rem;padding-bottom:calc(5rem + env(safe-area-inset-bottom));height:100dvh}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.page-title{font-size:1.5rem}.form-row,.form-row-3,.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.grid-movies{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.modal-backdrop{padding:0;align-items:flex-end}.modal{border-radius:var(--r-lg) var(--r-lg) 0 0;max-width:100%;max-height:92dvh}.modal-lg{max-width:100%}.cal-item{padding:.875rem 1rem}.cal-day{font-size:1.4rem}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0}.tab{white-space:nowrap}.link-preview-image{width:72px;min-width:72px}.modal-footer{flex-wrap:wrap}}
