:root{--bg:#0c0b10;--surface:#131219;--card:#1a1924;--card-high:#201f2e;--border:#ffffff12;--border-hi:#c9a96e40;--text:#f0ece0;--muted:#7a7585;--dimmed:#3e3a4a;--gold:#c9a96e;--gold-dim:#7a6035;--rose:#b8756a;--rose-dim:#6b3d38;--teal:#5a9ba5;--serif:"Playfair Display", Georgia, serif;--body:"Lora", Georgia, serif;--mono:"IBM Plex Mono", monospace;--sidebar:220px;--radius:10px;--ease:cubic-bezier(.25, 0, 0, 1);--trans-fast:.15s var(--ease);--trans-med:.3s var(--ease);--trans-slow:.6s var(--ease)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--body);cursor:default;height:100%;font-weight:300;overflow:hidden}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}input,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold)}body:before{content:"";pointer-events:none;z-index:9998;opacity:.6;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}#starfield{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.s{animation:tw var(--d) ease-in-out infinite var(--dl);background:#fff;border-radius:50%;position:absolute}@keyframes tw{0%,to{opacity:var(--lo)}50%{opacity:var(--hi)}}#app{z-index:1;height:100vh;display:flex;position:relative}#sidebar{width:var(--sidebar);min-width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;height:100vh;padding:0;display:flex;position:relative;overflow:hidden}#sidebar:before{content:"";pointer-events:none;background:radial-gradient(circle,#c9a96e0d 0%,#0000 70%);width:240px;height:240px;position:absolute;top:-80px;left:-80px}.sidebar-top{border-bottom:1px solid var(--border);padding:2rem 1.5rem 1.5rem}.sidebar-couple{font-family:var(--serif);background:linear-gradient(90deg, var(--gold), var(--rose), var(--gold));-webkit-text-fill-color:transparent;background-size:200% 100%;-webkit-background-clip:text;background-clip:text;margin-bottom:.4rem;font-size:1rem;font-weight:400;line-height:1.3;animation:4s ease-in-out infinite grad-shimmer}@keyframes grad-shimmer{0%,to{background-position:0%}50%{background-position:100%}}.sidebar-couple em{-webkit-text-fill-color:var(--gold);color:var(--gold);font-style:italic}.sidebar-since{font-family:var(--mono);letter-spacing:.2em;color:var(--muted);text-transform:uppercase;font-size:.58rem;font-weight:200}.sidebar-subtitle{font-family:var(--mono);color:var(--gold);letter-spacing:.05em;margin-top:.8rem;font-size:.65rem;font-weight:300}nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-section{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--dimmed);padding:.4rem 1rem .2rem;font-size:.52rem;font-weight:400}.nav-item{color:var(--muted);transition:color var(--trans-fast), background var(--trans-fast);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;padding:.7rem 1.5rem;font-size:.85rem;display:flex;position:relative}.nav-item:hover{color:var(--text);background:#ffffff08}.nav-item.active{color:var(--gold);background:#c9a96e0f}.nav-item.active:before{content:"";background:var(--gold);border-radius:0 2px 2px 0;width:3px;position:absolute;top:.4rem;bottom:.4rem;left:0}.nav-item.active:after{content:"";background:var(--gold);content:"";background:var(--gold);filter:blur(6px);opacity:.6;border-radius:0 2px 2px 0;width:1px;height:40%;position:absolute;top:50%;left:0;right:.75rem;transform:translateY(-50%)}.nav-item .nav-icon{transition:transform var(--trans-fast)}.nav-item:hover .nav-icon{transform:scale(1.2)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:1rem}.nav-badge{font-family:var(--mono);letter-spacing:0;background:var(--rose-dim);color:var(--rose);text-align:center;border-radius:8px;min-width:16px;margin-left:auto;padding:.05rem .35rem;font-size:.5rem}.nav-mobile-toggle-wrap{display:none}.nav-mobile-toggle{font-family:var(--mono);text-align:center;color:var(--muted);cursor:pointer;width:100%;transition:color var(--trans-fast);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.1rem;padding:.5rem .2rem;font-size:.6rem}.nav-mobile-toggle:hover{color:var(--text)}.nav-mobile-toggle .nav-icon{transition:transform .25s var(--ease)}.nav-mobile-toggle.open .nav-icon{transform:rotate(90deg)}.nav-secondary-popup{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);z-index:100;opacity:0;pointer-events:none;min-width:180px;transition:opacity .2s var(--ease), transform .2s var(--ease);padding:.5rem;position:fixed;bottom:80px;right:1rem;transform:translateY(8px)scale(.96);box-shadow:0 8px 32px #08071099}.nav-secondary-popup.open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.nav-secondary-popup-inner{flex-direction:column;gap:.25rem;display:flex}.nav-item--secondary{font-family:var(--mono);letter-spacing:.05em;color:var(--muted);transition:background var(--trans-fast), color var(--trans-fast);border-radius:8px;align-items:center;gap:.6rem;padding:.75rem 1rem;font-size:.7rem;text-decoration:none;display:flex}.nav-item--secondary:hover{background:var(--card);color:var(--text)}.nav-item--secondary.active{color:var(--gold)}.nav-item--secondary .nav-icon{font-size:1rem}.nav-item--secondary.nav-item--logout{border-top:1px solid var(--border);cursor:pointer;background:0 0;border-radius:0;width:100%;margin-top:.25rem;padding-top:.75rem}.nav-item--secondary.nav-item--logout:hover{color:var(--rose);background:var(--card);border-radius:8px}.sidebar-bottom{border-top:1px solid var(--border);padding:1rem 1.5rem}.sidebar-logout{width:100%;font-family:var(--mono);color:var(--muted);letter-spacing:.1em;cursor:pointer;transition:color var(--trans-fast), transform var(--trans-fast);background:0 0;border:none;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.6rem;display:flex}.sidebar-logout:hover{color:var(--rose);transform:translate(2px)}.sidebar-logout-icon{transition:transform var(--trans-fast);font-size:.85rem}.sidebar-logout:hover .sidebar-logout-icon{transform:rotate(-8deg)}#main{flex:1;position:relative;overflow:hidden auto}.page{min-height:100vh;padding:2.5rem 3rem;animation:none;display:none}.page.active{animation:page-in .5s var(--ease);display:block}.page.exit{animation:page-out .25s var(--ease) forwards;pointer-events:none;display:block}@keyframes page-in{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes page-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-10px)scale(.98)}}.page-header{border-bottom:1px solid var(--border);align-items:flex-end;gap:2rem;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.page-title{font-family:var(--serif);color:var(--text);font-size:2.2rem;font-weight:400;line-height:1}.page-subtitle{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem;font-size:.62rem;font-weight:200}.page-actions{gap:.75rem;margin-left:auto;display:flex}.btn{border-radius:var(--radius);font-family:var(--mono);letter-spacing:.1em;transition:all var(--trans-fast);align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.7rem;font-weight:300;display:inline-flex}.btn-primary{background:var(--gold);color:#0c0b10;font-weight:400}.btn-primary:hover{background:#d4b47a;transform:translateY(-1px);box-shadow:0 4px 20px #c9a96e4d}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{color:var(--text);border-color:var(--border-hi);background:#c9a96e0a}.btn-sm{padding:.35rem .7rem;font-size:.6rem}.view-toggle{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.view-toggle .vt-btn{color:var(--muted);cursor:pointer;transition:all var(--trans-fast);font-size:.6rem;font-family:var(--mono);background:0 0;border:none;align-items:center;gap:.3rem;padding:.35rem .65rem;display:flex}.view-toggle .vt-btn:hover{color:var(--text);background:#c9a96e0a}.view-toggle .vt-btn.active{color:var(--gold);background:#c9a96e1a}.view-toggle .vt-btn+.vt-btn{border-left:1px solid var(--border)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--trans-med);overflow:hidden}.card:hover{border-color:var(--border-hi)}#page-home{padding:0;position:relative}.home-hero{justify-content:center;align-items:center;height:100vh;min-height:480px;display:flex;position:relative;overflow:hidden}#orbit-canvas{width:100%;height:100%;position:absolute;inset:0}.home-hero-content{z-index:2;text-align:center;position:relative}.home-title{font-family:var(--serif);color:var(--text);margin-bottom:.8rem;font-size:clamp(2.5rem,5vw,4.5rem);font-weight:400;line-height:1}.home-title em{color:var(--gold);font-style:italic}.home-tagline{font-family:var(--mono);letter-spacing:.45em;color:var(--muted);text-transform:uppercase;font-size:.65rem}.hero-counter{flex-direction:column;align-items:center;gap:.6rem;margin-top:5rem;display:flex}.hero-counter-units{align-items:center;gap:1.2rem;display:flex}.hcu{text-align:center}.hcu-val{font-family:var(--serif);color:var(--gold);text-shadow:0 0 20px color-mix(in srgb, var(--gold) 30%, transparent);font-size:clamp(2.8rem,6vw,4.5rem);font-weight:400;line-height:1;display:block}.hcu-val--sm{text-shadow:none;font-size:clamp(1.2rem,2.5vw,1.6rem);display:inline}.hcu-label{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:.25rem;font-size:.5rem;display:block}.hcu-sep{font-family:var(--serif);color:var(--dimmed);align-self:center;margin-top:.25rem;font-size:clamp(1.4rem,3vw,2rem);line-height:1}.hcu-sep--sm{font-size:clamp(1rem,2vw,1.3rem)}.hero-counter-sub{opacity:.7;align-items:center;gap:.5rem;display:flex}.hero-counter-since{font-family:var(--mono);letter-spacing:.15em;color:var(--gold);margin-top:.3rem;font-size:.55rem}.home-body{padding:2.5rem 3rem}.home-grid{grid-template-columns:1fr 1fr 1fr;gap:1.2rem;margin-bottom:2rem;display:grid}.counter-card{grid-column:1/-1;justify-content:space-between;align-items:center;gap:2rem;padding:2rem 2.5rem;display:flex}.counter-units{gap:2.5rem;display:flex}.cu{text-align:center}.cu-val{font-family:var(--serif);color:var(--text);font-size:2.8rem;font-weight:400;line-height:1;display:block}.cu-label{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:.3rem;font-size:.55rem}.counter-sep{font-family:var(--serif);color:var(--dimmed);align-self:flex-start;margin-top:0;font-size:2.8rem}.counter-right{text-align:right}.counter-label{font-family:var(--mono);letter-spacing:.3em;color:var(--muted);text-transform:uppercase;margin-bottom:.5rem;font-size:.6rem;display:block}.counter-since{font-family:var(--serif);color:var(--gold);font-size:1rem;font-style:italic}.missyou-area{align-items:center;gap:1.5rem;padding:1.6rem 2rem;display:flex}#wish-btn{flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex;position:relative}#wish-btn:before{content:"";border:1px solid var(--rose-dim);transition:all var(--trans-med);border-radius:50%;position:absolute;inset:0}#wish-btn:hover:before{border-color:var(--rose);transform:scale(1.1);box-shadow:0 0 20px #b8756a33}#wish-btn svg{transition:transform var(--trans-med)}#wish-btn:hover svg{transform:scale(1.2)}#wish-btn.pop svg{animation:pop .5s var(--ease)}@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.5)}70%{transform:scale(.9)}to{transform:scale(1)}}.missyou-text h3{font-family:var(--serif);margin-bottom:.2rem;font-size:1rem;font-weight:400}.missyou-text p{font-family:var(--mono);color:var(--muted);letter-spacing:.1em;font-size:.62rem}#wish-feedback{font-family:var(--serif);color:var(--rose);opacity:0;transition:opacity var(--trans-med);margin-left:auto;font-size:.9rem;font-style:italic}#wish-feedback.show{opacity:1}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.2rem;display:grid}.photo-card{cursor:pointer;border-radius:var(--radius);aspect-ratio:1;transition:transform var(--trans-med), box-shadow var(--trans-med);position:relative;overflow:hidden;transform:rotate(.5deg)}.photo-card.odd{transform:rotate(-.8deg)}.photo-card:hover{transform:translateY(-4px)rotate(.5deg)scale(1.02);box-shadow:0 16px 40px #00000080,0 0 30px #c9a96e14}.photo-card.odd:hover{transform:translateY(-4px)rotate(-.8deg)scale(1.02)}.photo-thumb{object-fit:cover;width:100%;height:100%;display:block}.photo-thumb-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:2.5rem;display:flex}.photo-overlay{opacity:0;transition:opacity var(--trans-med);background:linear-gradient(#0000 50%,#0c0b10d9 100%);flex-direction:column;justify-content:flex-end;padding:.8rem;display:flex;position:absolute;inset:0}.photo-card:hover .photo-overlay{opacity:1}.photo-caption{font-family:var(--mono);letter-spacing:.1em;color:var(--text);font-size:.6rem}.photo-date{font-family:var(--mono);color:var(--gold);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.2rem;font-size:.55rem;display:-webkit-box;overflow:hidden}.album-card{background:0 0;overflow:visible}.album-stack{width:100%;height:100%;position:relative}.album-stack-back{border-radius:var(--radius);z-index:1;border:1px solid var(--border-hi);position:absolute;inset:-7px -7px 7px 7px;overflow:hidden}.album-stack-front{border-radius:var(--radius);z-index:2;border:1px solid var(--border-hi);position:absolute;inset:7px 7px -7px -7px;overflow:hidden}.album-stack-back img,.album-stack-front img{object-fit:cover;width:100%;height:100%}.upload-zone{aspect-ratio:1;border:1px dashed var(--border-hi);border-radius:var(--radius);cursor:pointer;transition:all var(--trans-med);background:var(--card);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex}.upload-zone:hover{border-color:var(--gold);background:#c9a96e0a}.upload-icon{color:var(--muted);font-size:1.5rem}.upload-label{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);text-align:center;font-size:.62rem}.modal-backdrop{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;animation:fade-in .2s var(--ease);background:#06060fd9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:calc(var(--radius) * 1.5);width:min(480px,92vw);animation:slide-up .25s var(--ease);padding:1.75rem}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.7rem}.modal-close-btn{color:var(--muted);transition:color var(--trans-fast);font-size:1rem;line-height:1}.modal-close-btn:hover{color:var(--text)}.upload-type-select{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.upload-type-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--trans-fast), background var(--trans-fast);flex-direction:column;align-items:center;gap:.4rem;padding:1.5rem 1rem;display:flex}.upload-type-btn:hover{border-color:var(--gold);background:#c9a96e0d}.upload-type-icon{font-size:1.8rem}.upload-type-label{font-family:var(--serif);color:var(--text);font-size:1rem}.upload-type-sub{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);font-size:.58rem}.upload-form{flex-direction:column;gap:1.1rem;display:flex}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-label{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-size:.6rem}.form-input{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--body);color:var(--text);transition:border-color var(--trans-fast);box-sizing:border-box;outline:none;width:100%;padding:.6rem .8rem;font-size:.85rem}.form-input:focus{border-color:var(--gold)}.form-input::placeholder{color:var(--dimmed)}.form-error{font-family:var(--mono);color:var(--rose);letter-spacing:.1em;border-radius:var(--radius);background:#b8756a14;padding:.4rem .6rem;font-size:.6rem;line-height:1.4}.file-drop-zone{background:var(--card);border:1px dashed var(--border-hi);border-radius:var(--radius);cursor:pointer;min-height:80px;transition:border-color var(--trans-fast);justify-content:center;align-items:center;padding:1rem;display:flex}.file-drop-zone:hover{border-color:var(--gold)}.file-drop-hint{font-family:var(--mono);color:var(--dimmed);letter-spacing:.1em;font-size:.65rem}.file-preview-single{align-items:center;gap:.75rem;width:100%;display:flex}.file-preview-single img{object-fit:cover;border-radius:calc(var(--radius) / 2);width:52px;height:52px}.file-preview-single span{font-family:var(--mono);color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.65rem;overflow:hidden}.file-preview-grid{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.file-preview-grid img{object-fit:cover;border-radius:calc(var(--radius) / 2);width:44px;height:44px}.file-preview-more{font-family:var(--mono);color:var(--muted);font-size:.65rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.foto-modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:calc(var(--radius) * 1.5);width:min(860px,94vw);max-height:88vh;animation:slide-up .25s var(--ease);display:flex;overflow:hidden}.foto-modal-img-wrap{background:var(--bg);flex:auto;justify-content:center;align-items:center;min-width:0;display:flex;overflow:hidden}.foto-modal-img{object-fit:contain;max-width:100%;max-height:88vh}.foto-modal-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:5rem;display:flex}.foto-modal-sidebar{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:1rem;width:220px;padding:1.25rem;display:flex}.foto-modal-sidebar-top{justify-content:flex-end;display:flex}.foto-modal-info{flex-direction:column;flex:1;gap:.5rem;display:flex}.foto-modal-title{font-family:var(--serif);color:var(--text);font-size:1rem;font-weight:400;line-height:1.3}.foto-modal-caption{font-family:var(--body);color:var(--muted);font-size:.8rem;line-height:1.5}.foto-modal-date{font-family:var(--mono);color:var(--gold);letter-spacing:.15em;margin-top:.25rem;font-size:.58rem}.foto-modal-edit{flex-direction:column;flex:1;gap:.75rem;display:flex}.foto-modal-menu-wrap{margin-top:auto;position:relative}.three-dots-btn{color:var(--dimmed);letter-spacing:.1em;transition:color var(--trans-fast);font-size:1.1rem;line-height:1}.three-dots-btn:hover{color:var(--muted)}.three-dots-menu{background:var(--card-high);border:1px solid var(--border-hi);border-radius:var(--radius);z-index:10;min-width:120px;position:absolute;bottom:calc(100% + 6px);right:30px;overflow:hidden}.three-dots-menu--below{background:var(--card-high);border:1px solid var(--border-hi);border-radius:var(--radius);z-index:10;min-width:135px;position:absolute;top:calc(100% + 6px);left:-78px;overflow:hidden}.three-dots-menu button,.three-dots-menu--below button{text-align:left;width:100%;font-family:var(--mono);letter-spacing:.1em;color:var(--text);transition:background var(--trans-fast);padding:.6rem .9rem;font-size:.65rem;display:block}.three-dots-menu button:hover,.three-dots-menu--below button:hover{background:var(--card)}.three-dots-menu .delete-opt,.three-dots-menu--below .delete-opt{color:var(--rose)}.album-modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:calc(var(--radius) * 1.5);width:min(760px,94vw);max-height:88vh;animation:slide-up .25s var(--ease);flex-direction:column;display:flex;overflow:hidden}.album-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem 1rem;display:flex}.album-modal-meta{flex-direction:column;flex:1;gap:.3rem;display:flex}.album-modal-title{font-family:var(--serif);color:var(--text);font-size:1.1rem;font-weight:400}.album-modal-caption{font-family:var(--body);color:var(--muted);font-size:.8rem}.album-edit-inline{flex-direction:column;gap:.5rem;display:flex}.back-btn{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);transition:color var(--trans-fast);font-size:.65rem}.back-btn:hover{color:var(--gold)}.delete-bar{border-bottom:1px solid var(--border);background:#b8756a12;justify-content:space-between;align-items:center;padding:.6rem 1.5rem;display:flex}.album-photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem;padding:1.25rem 1.5rem;display:grid;overflow-y:auto}.album-photo-item{cursor:pointer;border-radius:var(--radius);aspect-ratio:1;transition:transform var(--trans-fast), box-shadow var(--trans-fast);border:2px solid #0000;position:relative;overflow:hidden}.album-photo-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.album-photo-item.selected{border-color:var(--rose)}.album-photo-item img{object-fit:cover;width:100%;height:100%;display:block}.album-photo-placeholder{background:var(--card);justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;display:flex}.album-select-check{background:var(--rose);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:.4rem;right:.4rem}.album-expanded-view{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex;overflow:hidden}.album-expanded-img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:calc(88vh - 180px);animation:scale-in .25s var(--ease)}@keyframes scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.album-expanded-info{text-align:center;flex-direction:column;gap:.3rem;display:flex}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.empty-icon{opacity:.4;font-size:3rem}.empty-title{font-family:var(--serif);color:var(--muted);font-size:1.1rem;font-weight:400}.empty-sub{font-family:var(--mono);letter-spacing:.15em;color:var(--dimmed);font-size:.65rem}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-value{font-family:var(--body);color:var(--gold);background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-sizing:border-box;width:100%;padding:.5rem .75rem;font-size:.9rem}.write-form-divider{background:var(--border);height:1px;margin:-.2rem 0 .2rem}.letter-card{cursor:pointer;transition:all var(--trans-fast);flex-direction:column;gap:.3rem;padding:1.2rem 1.4rem;display:flex;position:relative}.letter-card:hover{border-color:var(--border-hi)}.letter-menu-below{z-index:10;background:var(--card-high);border:1px solid var(--border-hi);border-radius:var(--radius);min-width:120px;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.letter-menu-below button{text-align:left;width:100%;font-family:var(--mono);letter-spacing:.1em;color:var(--text);transition:background var(--trans-fast);padding:.6rem .9rem;font-size:.65rem;display:block}.letter-menu-below button:hover{background:var(--card)}.letter-menu-below .delete-opt{color:var(--rose)}.letter-modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:calc(var(--radius) * 1.5);width:min(620px,94vw);max-height:88vh;animation:slide-up .25s var(--ease);padding:2rem;overflow-y:auto}.letter-reader-from{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;font-size:.6rem}.letter-reader-subject{font-family:var(--serif);color:var(--text);margin-bottom:.4rem;font-size:1.6rem;font-weight:400}.letter-reader-date{font-family:var(--mono);color:var(--muted);letter-spacing:.15em;border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1.2rem;font-size:.6rem}.letter-reader-body{font-family:var(--body);color:var(--text);opacity:.85;font-size:.95rem;font-weight:300;line-height:2}.letter-reader-body p{margin-bottom:1.2em}.letter-reader-sig{font-family:var(--serif);color:var(--gold);margin-top:2rem;font-size:1.3rem;font-style:italic}.write-modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:calc(var(--radius) * 1.5);width:min(540px,94vw);animation:slide-up .25s var(--ease);padding:2rem}.write-form{flex-direction:column;gap:1.2rem;display:flex}.write-form-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.letter-textarea{resize:vertical;min-height:280px;line-height:1.8}#toast-area{z-index:9999;flex-direction:column;gap:.75rem;display:flex;position:fixed;bottom:2rem;right:2rem}.toast{background:var(--card);border:1px solid var(--border-hi);border-radius:var(--radius);font-family:var(--mono);letter-spacing:.05em;color:var(--text);animation:toast-in .3s var(--ease);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);align-items:center;gap:.6rem;max-width:300px;padding:.9rem 1.4rem;font-size:.7rem;display:flex}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.stacked-photos{height:200px;margin:1rem 0;position:relative}.stacked-photo{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:140px;height:160px;transition:all var(--trans-med);padding:.5rem;position:absolute}.stacked-photo img{object-fit:cover;border-radius:4px;width:100%;height:100%}.stacked-photo:first-child{z-index:1;transform:rotate(-4deg)translate(-20px)}.stacked-photo:nth-child(2){z-index:2;transform:rotate(-1deg)translate(0)}.stacked-photo:nth-child(3){z-index:3;transform:rotate(2deg)translate(20px)}.stacked-photo:nth-child(4){z-index:4;transform:rotate(5deg)translate(40px)}.stacked-photo:nth-child(5){z-index:5;transform:rotate(8deg)translate(60px)}.letter-preview-item{cursor:pointer;transition:all var(--trans-fast);padding:1.1rem 1.3rem;position:relative}.letter-preview-item:hover{border-color:var(--border-hi)}.li-from{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;font-size:.58rem}.li-subject{font-family:var(--serif);color:var(--text);margin-bottom:.2rem;font-size:.95rem;font-weight:400}.li-preview{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.li-date{font-family:var(--mono);color:var(--dimmed);letter-spacing:.1em;margin-top:.5rem;font-size:.58rem}.link-arrow{font-family:var(--mono);color:var(--gold);letter-spacing:.1em;margin-top:.5rem;font-size:.65rem;display:inline-block}.wave{border:1px solid var(--rose);opacity:0;border-radius:50%;position:absolute}.wave.active{animation:1s ease-out forwards wave-out}@keyframes wave-out{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}.shooting-star{pointer-events:none;z-index:1;width:var(--len);height:1px;top:var(--y);transform:rotate(var(--angle));animation:shoot var(--dur) ease-out forwards;background:linear-gradient(90deg,#0000,#fff5c8e6);position:fixed;left:-200px}.shooting-star:after{content:"";background:#fff5c8e6;border-radius:50%;width:4px;height:3px;position:absolute;top:-1px;right:0;box-shadow:0 0 6px 2px #ffe66466}@keyframes shoot{0%{transform:rotate(var(--angle)) translateX(0);opacity:0}5%{opacity:1}to{transform:rotate(var(--angle)) translateX(130vw);opacity:0}}.spinner{border:2px solid #fff3;border-top-color:var(--text);border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.btn-loading{align-items:center;gap:.5rem;display:flex}.modal-loading{opacity:.7;pointer-events:none}.file-drop-disabled{opacity:.5;cursor:not-allowed}.form-hint{font-family:var(--mono);color:var(--dimmed);margin-top:.2rem;font-size:.5rem;display:block}.capsulas-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.capsula-section-label{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-size:.58rem}.capsula-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--trans-fast), transform var(--trans-fast);padding:1.5rem;position:relative;overflow:hidden}.capsula-card:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d,0 0 20px #c9a96e0d}.capsula-card.sellada{border-color:#c9a96e26}.capsula-card.sellada:before{content:"";pointer-events:none;background:radial-gradient(at 0 0,#c9a96e0a 0%,#0000 60%);position:absolute;inset:0}.capsula-card.abierta{background:linear-gradient(135deg,#1a1924 0%,#1e1c2a 100%);border-color:#c9a96e59}.capsula-card.abierta:before{content:"";pointer-events:none;background:radial-gradient(at 100% 0,#c9a96e14 0%,#0000 60%);position:absolute;inset:0}@keyframes just-opened{0%{border-color:#c9a96e26;box-shadow:0 0 #c9a96e00}30%{border-color:#c9a96eb3;box-shadow:0 0 30px 6px #c9a96e40}to{border-color:#c9a96e59;box-shadow:0 0 #c9a96e00}}.capsula-card.just-opened{animation:1.8s cubic-bezier(.25,0,0,1) forwards just-opened}.capsula-card .card-state{letter-spacing:.3em;text-transform:uppercase;margin-bottom:.5rem;font-size:.55rem}.capsula-card.sellada .card-state{color:var(--muted)}.capsula-card.abierta .card-state{color:var(--gold)}.capsula-card .card-subject{font-family:var(--serif);color:var(--text);margin-bottom:.4rem;font-size:1.1rem;font-weight:400;line-height:1.3}.capsula-card .card-para{color:var(--muted);letter-spacing:.1em;font-size:.6rem}.capsula-card .card-divider{background:var(--border);height:1px;margin:1rem 0}.capsula-card .card-open-date{color:var(--gold);letter-spacing:.1em;font-size:.6rem}.card-countdown{flex-wrap:wrap;align-items:baseline;gap:.5rem;display:flex}.cdc-unit{text-align:center}.cdc-val{font-family:var(--serif);color:var(--gold);font-size:1.3rem;display:block}.cdc-val.sec-val{color:var(--gold-dim);font-size:1rem}.cdc-label{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:.48rem}.cdc-sep{font-family:var(--serif);color:var(--dimmed);margin-bottom:.2rem;font-size:.9rem}.scb-row{justify-content:center;align-items:baseline;gap:.8rem;margin:1.2rem 0;display:flex}.scb-unit{text-align:center}.scb-val{font-family:var(--serif);color:var(--gold);min-width:2ch;font-size:1.8rem;line-height:1;display:block}.scb-unit.sec .scb-val{color:var(--gold-dim);font-size:1.2rem}.scb-label{color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-top:.2rem;font-size:.48rem}.scb-sep{font-family:var(--serif);color:var(--dimmed);margin-bottom:.3rem;font-size:1.3rem}.sealed-msg{text-align:center;padding:1.5rem 1rem}.sealed-msg .sealed-icon{margin-bottom:1rem;font-size:2.5rem}.sealed-msg strong{color:var(--gold);font-weight:400;font-family:var(--serif);margin-bottom:.5rem;font-size:1rem;display:block}.sealed-msg p{color:var(--muted);letter-spacing:.05em;font-size:.7rem;line-height:1.7}.capsule-reader-badge{letter-spacing:.25em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.4rem;margin-bottom:1rem;font-size:.55rem;display:inline-flex}.capsule-reader-badge:before{content:"";background:var(--gold);border-radius:50%;width:6px;height:6px;display:inline-block}.capsule-reader-subject{font-family:var(--serif);color:var(--text);margin-bottom:.3rem;font-size:1.8rem;font-weight:400;line-height:1.2}.capsule-reader-meta{color:var(--muted);letter-spacing:.1em;margin-bottom:1.5rem;font-size:.6rem}.capsule-reader-body{color:var(--text);white-space:pre-line;border-left:2px solid var(--gold-dim);padding-left:1rem;font-size:.9rem;line-height:1.85}.capsule-reader-date{color:var(--dimmed);letter-spacing:.1em;text-align:right;margin-top:1.5rem;font-size:.58rem}.confirm-box{background:var(--card-high);border:1px solid var(--border-hi);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.25rem 1.5rem}.confirm-box>p{color:var(--muted);margin-bottom:.75rem;font-size:.68rem}.confirm-detail{flex-direction:column;gap:.5rem;display:flex}.confirm-row{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.confirm-key{letter-spacing:.15em;text-transform:uppercase;color:var(--dimmed);flex-shrink:0;font-size:.55rem}.confirm-val{font-family:var(--serif);color:var(--text);text-align:right;font-size:.85rem}.confirm-val.encrypted{font-family:var(--mono);color:var(--muted);word-break:break-all;text-align:right;font-size:.58rem}.cosmos-modal-box{max-width:640px}.cosmos-header-area{text-align:center;border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding:.5rem 0 1.5rem}.cosmos-big-icon{margin-bottom:.5rem;font-size:2.8rem}.cosmos-header-area h3{font-family:var(--serif);color:var(--teal);font-size:1.3rem;font-weight:400}.cosmos-header-area p{color:var(--muted);letter-spacing:.05em;margin-top:.3rem;font-size:.62rem;line-height:1.6}.cosmos-list{flex-direction:column;gap:.75rem;max-height:50vh;display:flex;overflow-y:auto}.cosmos-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--trans-fast);align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.cosmos-item:hover{border-color:#5a9ba540}.cosmos-item-icon{opacity:.4;flex-shrink:0;font-size:1.3rem}.cosmos-item-info{flex:1;min-width:0}.cosmos-item-subject{font-family:var(--serif);color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-size:.95rem;overflow:hidden}.cosmos-item-meta{color:var(--muted);letter-spacing:.08em;flex-wrap:wrap;gap:.8rem;font-size:.55rem;display:flex}.cosmos-item-action{flex-shrink:0}.btn-cosmos{color:var(--teal);border-radius:var(--radius);transition:all var(--trans-fast);cursor:pointer;background:0 0;border:1px solid #5a9ba559;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.7rem;display:inline-flex}.btn-cosmos:hover{background:#5a9ba514;border-color:#5a9ba599}.btn-send-space{color:var(--teal);border-radius:var(--radius);transition:all var(--trans-fast);cursor:pointer;background:0 0;border:1px solid #5a9ba54d;padding:.6rem 1.2rem;font-size:.7rem}.btn-send-space:hover{background:#5a9ba514}.btn-restore{color:var(--teal);border-radius:var(--radius);transition:all var(--trans-fast);cursor:pointer;background:0 0;border:1px solid #5a9ba54d;padding:.4rem .9rem;font-size:.65rem}.btn-restore:hover{background:#5a9ba514}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.tl-header{text-align:center;padding:1.5rem 0 2rem}.tl-header-label{letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;font-size:.58rem}.tl-header h1{font-family:var(--serif);color:var(--text);font-size:clamp(1.6rem,4vw,2.6rem);font-weight:400;line-height:1.15}.tl-header h1 em{color:var(--gold);font-style:italic}.tl-header-sub{color:var(--muted);letter-spacing:.12em;margin-top:.6rem;font-size:.62rem}.stats-bar{flex-wrap:wrap;justify-content:center;gap:2rem;margin-bottom:2rem;display:flex}.stat-item{text-align:center}.stat-val{font-family:var(--serif);color:var(--gold);font-size:1.6rem;line-height:1;display:block}.stat-label{color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-top:.2rem;font-size:.5rem}.stat-divider{background:var(--border);align-self:stretch;width:1px}.top-bar{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:2.5rem;display:flex}.top-bar .view-toggle .vt-btn{padding:.45rem .9rem}.year-filter-wrap{justify-content:center;margin-bottom:2.5rem;display:flex;position:relative}.year-filter-wrap:before,.year-filter-wrap:after{content:"";z-index:2;pointer-events:none;width:3rem;position:absolute;top:0;bottom:0}.year-filter-wrap:before{background:linear-gradient(to right, var(--bg), transparent);left:0}.year-filter-wrap:after{background:linear-gradient(to left, var(--bg), transparent);right:0}.year-filter{scrollbar-width:none;-ms-overflow-style:none;align-items:flex-start;gap:.75rem;padding:.25rem 3rem;display:flex;overflow-x:auto}.year-filter::-webkit-scrollbar{display:none}.yf-all{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);cursor:pointer;transition:all .2s var(--ease);white-space:nowrap;font-size:.58rem;font-family:var(--mono);background:0 0;border-radius:20px;align-self:center;padding:.45rem 1rem}.yf-all:hover{border-color:var(--border-hi);color:var(--text)}.yf-all.active{border-color:var(--border-hi);color:var(--gold);background:#c9a96e12}.yf-year{cursor:pointer;transition:all .25s var(--ease);flex-direction:column;flex-shrink:0;align-items:center;display:flex;position:relative}.yf-planet{border:1px solid var(--dimmed);width:52px;height:52px;transition:all .25s var(--ease);background:radial-gradient(circle at 35% 35%,#252038,#0f0e18);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative;box-shadow:0 0 #c9a96e00}.yf-ring{pointer-events:none;border:1px solid #c9a96e1f;border-radius:50%;width:68px;height:18px;transition:border-color .25s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotateX(72deg)}.yf-year-label{font-family:var(--mono);color:var(--muted);letter-spacing:.08em;margin-top:.4rem;font-size:.62rem;font-weight:500;transition:color .25s}.yf-count{color:var(--dimmed);letter-spacing:.1em;margin-top:.15rem;font-size:.48rem;transition:color .25s}.yf-year:hover .yf-planet{border-color:#c9a96e4d;box-shadow:0 0 12px #c9a96e1a}.yf-year:hover .yf-year-label{color:var(--gold)}.yf-year:hover .yf-ring{border-color:#c9a96e40}.yf-year.active .yf-planet{background:radial-gradient(circle at 35% 35%,#2a2540,#150f28);border-color:#c9a96e80;box-shadow:0 0 20px #c9a96e33,inset 0 0 12px #c9a96e0d}.yf-year.active .yf-ring{border-color:#c9a96e66}.yf-year.active .yf-year-label{color:var(--gold)}.yf-year.active .yf-count{color:var(--gold-dim)}.yf-year.active:after{content:"";background:var(--gold);border-radius:50%;width:4px;height:4px;margin:.3rem auto 0;display:block}.timeline{position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, transparent 0%, var(--dimmed) 5%, var(--dimmed) 95%, transparent 100%);z-index:0;width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.gallery-timeline:before{content:none}.timeline-particles{pointer-events:none;z-index:0;width:20px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.tp{background:var(--gold);opacity:0;width:2px;height:2px;animation:float-up var(--dur,6s) var(--delay,0s) infinite linear;border-radius:50%;position:absolute;left:50%;transform:translate(-50%)}@keyframes float-up{0%{opacity:0;transform:translate(-50%)translateY(0)}10%{opacity:.6}90%{opacity:.3}to{opacity:0;transform:translate(-50%)translateY(-80px)}}.year-separator{z-index:2;pointer-events:none;justify-content:center;align-items:center;margin:2rem 0;display:flex;position:relative}.year-planet-tl{justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative}.year-planet-core-tl{z-index:2;background:radial-gradient(circle at 35% 35%,#2a2540,#0f0e18);border:1px solid #c9a96e4d;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;display:flex;position:relative;box-shadow:0 0 20px #c9a96e1a,inset 0 0 15px #00000080}.year-planet-core-tl span{font-family:var(--mono);color:var(--gold);letter-spacing:.1em;font-size:.7rem;font-weight:500}.year-planet-ring-tl{z-index:1;border:1px solid #c9a96e33;border-radius:50%;width:78px;height:22px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotateX(72deg)}.add-between{z-index:2;opacity:0;transition:opacity .25s var(--ease);justify-content:center;margin:.4rem 0;display:flex;position:relative}.timeline:hover .add-between,.add-between:hover{opacity:1}.add-between-btn{background:var(--surface);border:1px dashed var(--dimmed);color:var(--muted);font-family:var(--mono);letter-spacing:.12em;cursor:pointer;transition:all .2s var(--ease);border-radius:20px;align-items:center;gap:.4rem;padding:.3rem 1rem;font-size:.58rem;display:flex}.add-between-btn:hover{border-color:var(--gold-dim);color:var(--gold);background:#c9a96e0d}.tl-item{z-index:2;grid-template-columns:1fr 60px 1fr;align-items:start;gap:0;margin:.5rem 0;display:grid;position:relative}.tl-item.left .tl-card-wrap{grid-column:1;justify-content:flex-end;padding-right:2rem;display:flex}.tl-item.left .tl-node-wrap{grid-column:2}.tl-item.left .tl-empty{grid-column:3}.tl-item.right .tl-empty{grid-column:1}.tl-item.right .tl-node-wrap{grid-column:2}.tl-item.right .tl-card-wrap{grid-column:3;justify-content:flex-start;padding-left:2rem;display:flex}.tl-node-wrap{justify-content:center;padding-top:1.4rem;display:flex}.tl-node{cursor:pointer;transition:transform .2s var(--ease);justify-content:center;align-items:center;display:flex;position:relative}.tl-node:hover{transform:scale(1.15)}.node-normal{background:var(--gold-dim);border:2px solid var(--gold);border-radius:50%;width:12px;height:12px}.node-high{border:2px solid var(--gold);background:radial-gradient(circle at 40% 40%,#c9a96e,#7a6035);border-radius:50%;width:18px;height:18px;animation:3s infinite pulse-high;box-shadow:0 0 10px #c9a96e66}@keyframes pulse-high{0%,to{box-shadow:0 0 8px #c9a96e66}50%{box-shadow:0 0 18px #c9a96eb3}}.node-vhigh{filter:drop-shadow(0 0 6px #c9a96ee6);justify-content:center;align-items:center;width:24px;height:24px;font-size:1rem;animation:2s infinite pulse-vhigh;display:flex}@keyframes pulse-vhigh{0%,to{filter:drop-shadow(0 0 4px #c9a96eb3);transform:scale(1)}50%{filter:drop-shadow(0 0 14px #c9a96e);transform:scale(1.15)}}.node-vhigh-ring{border:1px solid #c9a96e4d;border-radius:50%;width:36px;height:36px;animation:2s infinite ring-expand;position:absolute}@keyframes ring-expand{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.5)}}.tl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;max-width:360px;transition:border-color var(--trans-fast), transform var(--trans-fast), box-shadow var(--trans-fast);padding:1.25rem 1.4rem;position:relative;overflow:hidden}.tl-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d,0 0 20px #c9a96e0a}.tl-card.intensity-normal:hover{border-color:var(--border-hi)}.tl-card.intensity-high{background:linear-gradient(135deg,#1a1924 0%,#1d1b2a 100%);border-color:#c9a96e33}.tl-card.intensity-high:hover{border-color:#c9a96e80;box-shadow:0 4px 24px #c9a96e1a}.tl-card.intensity-high:before{content:"";pointer-events:none;background:radial-gradient(at 0 0,#c9a96e0f 0%,#0000 60%);position:absolute;inset:0}.tl-card.intensity-vhigh{background:linear-gradient(135deg,#1c1a2a 0%,#201828 50%,#1a1c24 100%);border-color:#c9a96e66}.tl-card.intensity-vhigh:hover{border-color:#c9a96eb3;box-shadow:0 6px 32px #c9a96e26}.tl-card.intensity-vhigh:before{content:"";pointer-events:none;background:radial-gradient(at 10% 20%,#b8756a12 0%,#0000 50%),radial-gradient(at 80% 80%,#c9a96e14 0%,#0000 50%),radial-gradient(#5a9ba50a 0%,#0000 60%);position:absolute;inset:0}.tl-connector{background:var(--dimmed);width:2rem;height:1px;position:absolute;top:50%}.tl-item.left .tl-connector{right:-2rem}.tl-item.right .tl-connector{left:-2rem}.card-category{letter-spacing:.2em;text-transform:uppercase;border:1px solid;border-radius:20px;align-items:center;gap:.35rem;margin-bottom:.6rem;padding:.2rem .6rem;font-size:.52rem;display:inline-flex}.cat-primer-vez{color:#b8756a;background:#b8756a12;border-color:#b8756a4d}.cat-viaje{color:var(--teal);background:#5a9ba512;border-color:#5a9ba54d}.cat-celebracion{color:var(--gold);background:#c9a96e12;border-color:#c9a96e4d}.cat-cotidiano{color:var(--muted);border-color:var(--border);background:0 0}.cat-hito{color:#9b8ec4;background:#9b8ec412;border-color:#9b8ec44d}.card-emoji{margin-bottom:.5rem;font-size:1.6rem;line-height:1;display:block}.intensity-vhigh .card-emoji{font-size:2rem}.card-title{font-family:var(--serif);margin-bottom:.4rem;font-weight:400;line-height:1.25}.intensity-normal .card-title{color:var(--text);font-size:1rem}.intensity-high .card-title{color:var(--text);font-size:1.1rem}.intensity-vhigh .card-title{color:#f5efe0;font-size:1.25rem}.card-date{color:var(--muted);letter-spacing:.12em;margin-bottom:.75rem;font-size:.55rem}.card-desc{font-family:var(--body);color:var(--muted);font-size:.78rem;line-height:1.65}.intensity-high .card-desc{color:#9a9096}.intensity-vhigh .card-desc{color:#a09890}.intensity-badge{letter-spacing:.2em;text-transform:uppercase;border-radius:20px;padding:.2rem .65rem;font-size:.48rem;position:absolute;top:.75rem;right:.75rem}.badge-normal{display:none}.badge-high{color:var(--gold);background:#c9a96e12;border:1px solid #c9a96e40}.badge-vhigh{color:#f0e0c0;background:#c9a96e1f;border:1px solid #c9a96e66}.card-actions{opacity:0;transition:all .2s var(--ease);gap:.4rem;margin-top:1rem;display:flex;transform:translateY(4px)}.tl-card:hover .card-actions{opacity:1;transform:translateY(0)}.card-private-note{border-left:2px solid var(--dimmed);font-family:var(--body);color:var(--dimmed);background:#0003;border-radius:0 4px 4px 0;margin-top:.8rem;padding:.6rem .8rem;font-size:.72rem;font-style:italic}.tl-card{transition:border-color var(--trans-fast), transform var(--trans-fast), box-shadow var(--trans-fast), padding .35s var(--ease)}.card-desc,.card-actions,.card-private-note{transition:max-height .35s var(--ease), opacity .3s var(--ease) 50ms, padding .3s var(--ease), margin .3s var(--ease);opacity:1;max-height:400px;padding-top:inherit;padding-bottom:inherit;margin-top:inherit;margin-bottom:inherit;overflow:hidden}.card-emoji{transition:font-size .35s var(--ease), margin-bottom .35s var(--ease)}.intensity-vhigh .card-title,.intensity-normal .card-title,.intensity-high .card-title{transition:font-size .35s var(--ease)}.tl-view-wrapper.compact .card-desc,.tl-view-wrapper.compact .card-actions,.tl-view-wrapper.compact .card-private-note{opacity:0;max-height:0;margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;overflow:hidden}.tl-view-wrapper.compact .tl-card{padding:.85rem 1.1rem}.tl-view-wrapper.compact .card-emoji{margin-bottom:.3rem;font-size:1.1rem}.tl-view-wrapper.compact .intensity-vhigh .card-title{font-size:1rem}.tl-view-wrapper.compact .intensity-normal .card-title,.tl-view-wrapper.compact .intensity-high .card-title{font-size:.9rem}.tl-view-wrapper.compact .tl-card.card-expanded{cursor:pointer;padding:1.25rem 1.4rem}.tl-view-wrapper.compact .tl-card.card-expanded .card-emoji{margin-bottom:.5rem;font-size:1.6rem}.tl-view-wrapper.compact .tl-card.card-expanded .intensity-vhigh .card-emoji{font-size:2rem}.tl-view-wrapper.compact .tl-card.card-expanded.intensity-vhigh .card-title{font-size:1.25rem}.tl-view-wrapper.compact .tl-card.card-expanded.intensity-high .card-title{font-size:1.1rem}.tl-view-wrapper.compact .tl-card.card-expanded.intensity-normal .card-title{font-size:1rem}.tl-view-wrapper.compact .tl-card.card-expanded .card-desc,.tl-view-wrapper.compact .tl-card.card-expanded .card-actions{opacity:1;max-height:400px;margin-top:.75rem;margin-bottom:0;padding-top:.55rem;padding-bottom:0}.tl-view-wrapper.compact .tl-card.card-expanded .card-private-note,.tl-view-wrapper.expanded .card-private-note{opacity:1;max-height:400px;margin-top:.8rem;padding:.6rem .8rem}.tl-view-wrapper.slide-next{animation:.5s slideFromRight}.tl-view-wrapper.slide-prev{animation:.5s slideFromLeft}@keyframes slideFromRight{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes slideFromLeft{0%{opacity:0;transform:translate(-60px)}to{opacity:1;transform:translate(0)}}.tl-end{z-index:2;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 0 1rem;display:flex;position:relative}.tl-end-dot{background:var(--dimmed);border-radius:50%;width:8px;height:8px}.tl-end-label{color:var(--dimmed);letter-spacing:.25em;text-transform:uppercase;font-size:.55rem}.date-range-hint{color:var(--gold);letter-spacing:.05em;background:#c9a96e12;border:1px solid #c9a96e33;border-radius:6px;margin-bottom:1.2rem;padding:.4rem .8rem;font-size:.6rem;display:inline-block}.intensity-picker{gap:.6rem;display:flex}.ip-option{border:1px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all .2s var(--ease);flex:1;padding:.7rem .5rem}.ip-option .ip-icon{margin-bottom:.3rem;font-size:1.2rem;display:block}.ip-option .ip-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.55rem}.ip-option:hover:not(.selected){border-color:var(--dimmed)}.ip-option.selected.normal{border-color:var(--border-hi);background:#c9a96e0f}.ip-option.selected.normal .ip-label{color:var(--gold)}.ip-option.selected.high{background:#c9a96e1a;border-color:#c9a96e66}.ip-option.selected.high .ip-label{color:var(--gold)}.ip-option.selected.vhigh{background:#c9a96e24;border-color:#c9a96e99;box-shadow:0 0 16px #c9a96e1f}.ip-option.selected.vhigh .ip-label{color:var(--gold)}.emoji-grid{flex-wrap:wrap;gap:.5rem;margin-top:.4rem;display:flex}.emoji-opt{border:1px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .15s;display:flex}.emoji-opt:hover{border-color:var(--border-hi);background:#c9a96e0f}.emoji-opt.active{border-color:var(--gold);background:#c9a96e1a}.audio-player{border-top:1px solid var(--border);padding:.6rem 1rem}.ap-inner{flex-direction:column;gap:.4rem;display:flex}.ap-track-info{justify-content:space-between;align-items:center;gap:.3rem;display:flex}.ap-track-label{font-family:var(--serif);letter-spacing:.04em;color:var(--dimmed);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.ap-track-title{color:var(--text)}.ap-track-artist{color:var(--gold)}.ap-track-count{font-family:var(--mono);color:var(--muted);flex-shrink:0;font-size:.42rem}.ap-progress-row{align-items:center;gap:.3rem;display:flex}.ap-time{font-family:var(--mono);color:var(--muted);text-align:center;flex-shrink:0;min-width:2.6em;font-size:.42rem}.ap-seek{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;height:3px}.ap-seek::-webkit-slider-thumb{-webkit-appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:10px;height:10px}.ap-seek::-moz-range-thumb{background:var(--gold);cursor:pointer;border:none;border-radius:50%;width:10px;height:10px}.ap-loading{font-family:var(--mono);color:var(--muted);text-align:center;font-size:.45rem}.ap-controls{justify-content:center;align-items:center;gap:.5rem;display:flex}.ap-btn{background:var(--card);border:1px solid var(--border);cursor:pointer;width:28px;height:28px;transition:all var(--trans-fast);color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.6rem;display:flex}.ap-btn:hover{border-color:var(--gold-dim);color:var(--gold);background:#c9a96e14}.ap-play{background:var(--card-high);width:32px;height:32px;font-size:.7rem}.ap-volume-row{align-items:center;gap:.4rem;padding:0 .2rem;display:flex}.ap-vol-icon{opacity:.5;flex-shrink:0;font-size:.55rem;line-height:1}.ap-vol-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;height:3px}.ap-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:10px;height:10px}.ap-vol-slider::-moz-range-thumb{background:var(--gold);cursor:pointer;border:none;border-radius:50%;width:10px;height:10px}.ap-mobile-trigger,.ap-mobile-overlay{display:none}@media (max-width:768px){.audio-player{display:none}.ap-mobile-trigger{z-index:60;background:var(--card-high);border:1px solid var(--border-hi);width:44px;height:44px;color:var(--gold);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform var(--trans-fast);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:fixed;bottom:5rem;left:1rem;box-shadow:0 4px 16px #0000004d}.ap-mobile-trigger:active{transform:scale(.9)}.ap-mobile-overlay{z-index:70;opacity:0;pointer-events:none;transition:opacity var(--trans-med);background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.ap-mobile-overlay.open{opacity:1;pointer-events:auto}.ap-mobile-panel{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;border:1px solid var(--border);width:100%;max-width:400px;transition:transform .3s var(--ease);border-bottom:none;padding:1.5rem 2rem 2rem;position:relative;transform:translateY(100%)}.ap-mobile-overlay.open .ap-mobile-panel{transform:translateY(0)}.ap-mobile-close{color:var(--muted);cursor:pointer;font-size:.8rem;line-height:1;position:absolute;top:1rem;right:1rem}.ap-mobile-panel .ap-inner{align-items:center;width:100%}.ap-mobile-panel .ap-track-info,.ap-mobile-panel .ap-progress-row{width:100%}.ap-mobile-panel .ap-controls{gap:1rem}.ap-mobile-panel .ap-btn{width:36px;height:36px;font-size:.8rem}.ap-mobile-panel .ap-play{width:44px;height:44px;font-size:.9rem}.ap-mobile-panel .ap-volume-row{width:100%;max-width:200px}.ap-mobile-panel .ap-track-label{margin-bottom:.6rem;font-size:1rem}:root{--sidebar:0px}#sidebar{border-right:none;border-top:1px solid var(--border);z-index:50;flex-direction:row;width:100%;height:auto;padding:0;position:fixed;bottom:0;left:0;right:0}.sidebar-top,.nav-section,.sidebar-bottom{display:none}nav{flex-direction:row;gap:0;width:100%;padding:0;display:flex}nav>*{flex:1;min-width:0}.nav-item-wrap--mobile-hide{display:none}.nav-mobile-toggle-wrap{display:flex}.nav-mobile-toggle-wrap>*{flex:1}nav>:first-child{order:3}nav>:nth-child(2){order:2}nav>:nth-child(3){order:1}nav>:nth-child(5){order:4}nav>:nth-child(7){order:5}.nav-item{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.1rem;padding:.5rem .2rem;font-size:.6rem}.nav-item.active:before{border-radius:0 0 2px 2px;width:100%;height:2px;top:0;bottom:auto;left:0}.nav-item.active:after{display:none}.nav-item .nav-icon{font-size:1.1rem}.nav-badge{padding:.05rem .3rem;font-size:.45rem;position:absolute;top:4px;right:4px}#app{flex-direction:column}#main{height:calc(100vh - 70px);padding-bottom:70px}.page{padding:1.5rem}.home-grid{grid-template-columns:1fr}.hero-counter-units{gap:.6rem}.hcu-sep{color:var(--gold);opacity:.9;font-size:1.6rem}.hcu-sep--sm{font-size:1.2rem}.counter-card{flex-direction:column;align-items:flex-start}.home-title{font-size:2rem}.missyou-area{flex-wrap:wrap;justify-content:center;gap:1rem}#wish-feedback{text-align:center;width:100%;margin-left:0}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem}.foto-modal-box{flex-direction:column;width:96vw;max-height:92vh;overflow-y:auto}.foto-modal-img-wrap{flex-shrink:0;width:100%;max-height:none}.foto-modal-img{object-fit:contain;width:100%;height:auto;max-height:70vh}.foto-modal-sidebar{border-left:none;border-top:1px solid var(--border);flex-flow:wrap;align-items:flex-start;gap:.75rem;width:100%;padding:1rem}.foto-modal-sidebar-top{justify-content:flex-end;width:100%}.foto-modal-info{flex-flow:wrap;align-items:center;gap:.5rem}.foto-modal-edit{width:100%}.album-modal-box{width:96vw;max-height:92vh}.album-photos-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem;padding:1rem}.letter-modal-box,.write-modal-box{width:96vw;padding:1.5rem}.letter-reader-subject{font-size:1.3rem}.letter-reader-body{font-size:.9rem}.letter-textarea{min-height:200px}.modal-box{padding:1.25rem}.upload-type-select{gap:.75rem}.capsulas-grid{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.capsule-reader-subject,.scb-val{font-size:1.4rem}.cosmos-list{max-height:40vh}.cosmos-item{flex-wrap:wrap}.cosmos-item-action{justify-content:flex-end;width:100%;display:flex}.page-header{text-align:center;flex-direction:column;align-items:center;gap:1rem}.page-header .page-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;margin-left:0}.tl-header{padding:1rem 0 1.5rem}.tl-header h1{font-size:1.5rem}.tl-header-sub{font-size:.55rem}.stats-bar{gap:1rem}.stat-divider{display:none}.stat-val{font-size:1.3rem}.top-bar{flex-direction:column;align-items:center;gap:.75rem}.timeline:before,.timeline-particles{left:24px;transform:none}.year-separator{justify-content:flex-start;padding-left:4px}.tl-item{grid-template-columns:48px 1fr}.tl-item.left .tl-card-wrap,.tl-item.right .tl-card-wrap{grid-area:1/2;justify-content:flex-start;padding:0 0 0 1rem}.tl-item.left .tl-node-wrap,.tl-item.right .tl-node-wrap{grid-area:1/1;justify-content:center;padding-top:1.2rem}.tl-item.left .tl-empty,.tl-item.right .tl-empty,.tl-item.left .tl-connector,.tl-item.right .tl-connector{display:none}.tl-card{max-width:100%}.add-between{justify-content:flex-start;padding-left:4px}.intensity-picker{gap:.4rem}.year-filter{padding:.25rem 2rem}}.view-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.view-btn{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all var(--trans-fast);background:0 0;border:none;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.65rem;display:flex}.view-btn:hover{color:var(--text)}.view-btn.active{background:var(--card-high);color:var(--gold)}.gallery-stats-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:2rem;margin-bottom:1.5rem;padding:1rem 1.25rem;display:flex}.gallery-stat-item{flex-direction:column;gap:.15rem;display:flex}.gallery-stat-val{font-family:var(--serif);color:var(--gold);text-shadow:0 0 20px #c9a96e40;font-size:1.5rem;line-height:1}.gallery-stat-val.rose{color:var(--rose)}.gallery-stat-label{font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;color:var(--muted);font-size:.55rem}.gallery-stat-sep{background:var(--border);align-self:stretch;width:1px}.gallery-filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.filter-label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--dimmed);font-size:.6rem}.filter-chip{border:1px solid var(--border);font-family:var(--mono);color:var(--muted);cursor:pointer;transition:all var(--trans-fast);letter-spacing:.05em;background:0 0;border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .8rem;font-size:.6rem;display:inline-flex}.filter-chip:hover{border-color:var(--border-hi);color:var(--text)}.filter-chip.active{border-color:var(--rose);color:var(--rose);background:#b8756a14}.timeline{flex-direction:column;gap:3.5rem;display:flex}.month-section{animation:fadeSlideUp .45s var(--ease) both}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.month-header{align-items:center;gap:1.2rem;margin-bottom:1.5rem;display:flex}.month-line{background:linear-gradient(to right, var(--gold-dim), transparent);flex:1;height:1px}.month-label{flex-shrink:0;align-items:baseline;gap:.5rem;display:flex}.month-name{font-family:var(--serif);color:var(--gold);font-size:1.15rem;font-style:italic}.month-year{font-family:var(--mono);color:var(--muted);letter-spacing:.2em;font-size:.6rem}.month-count{font-family:var(--mono);color:var(--dimmed);letter-spacing:.1em;margin-left:.3rem;font-size:.55rem}.month-content{grid-template-columns:260px 1fr;align-items:start;gap:1rem;display:grid}.month-content.no-featured{grid-template-columns:1fr}.featured-photo{aspect-ratio:3/4;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:border-color var(--trans-med), transform var(--trans-med);flex-shrink:0;position:relative;overflow:hidden}.featured-photo:hover{border-color:var(--border-hi);transform:scale(1.015)}.featured-photo img,.featured-photo .photo-placeholder-inner{object-fit:cover;width:100%;height:100%;transition:transform var(--trans-med);display:block}.featured-photo:hover img,.featured-photo:hover .photo-placeholder-inner{transform:scale(1.04)}.featured-badge{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:#0c0b10;background:var(--gold);pointer-events:none;border-radius:4px;padding:.25rem .55rem;font-size:.5rem;position:absolute;top:.7rem;left:.7rem}.featured-overlay{opacity:0;transition:opacity var(--trans-med);pointer-events:none;background:linear-gradient(#0000 45%,#0c0b10d9 100%);flex-direction:column;justify-content:flex-end;padding:1rem;display:flex;position:absolute;inset:0}.featured-photo:hover .featured-overlay{opacity:1}.featured-caption{font-family:var(--body);color:var(--text);font-size:.82rem;font-style:italic;line-height:1.5}.featured-date{font-family:var(--mono);color:var(--gold);letter-spacing:.15em;margin-top:.3rem;font-size:.55rem}.special-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;width:22px;height:22px;transition:transform var(--trans-fast);z-index:2;background:#b8756ad9;border-radius:50%;justify-content:center;align-items:center;font-size:.65rem;display:flex;position:absolute;top:.45rem;right:.45rem}.special-badge-featured{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;z-index:2;background:#b8756ad9;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:.75rem;display:flex;position:absolute;top:.7rem;right:.7rem}.special-toggle-btn{border:1px solid var(--border-hi);cursor:pointer;opacity:0;width:24px;height:24px;transition:opacity var(--trans-fast), background var(--trans-fast);z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0c0b1099;border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;display:flex;position:absolute;top:.45rem;right:.45rem}.photo-card:hover .special-toggle-btn{opacity:1}.special-toggle-btn:hover{background:#b8756a66}.special-toggle-btn.is-special{opacity:1;background:#b8756abf}.photos-rail{flex-direction:column;gap:.75rem;display:flex}.photos-row{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;display:grid}.album-rail-card{aspect-ratio:1;border-radius:var(--radius);border:1px solid var(--border-hi);cursor:pointer;background:var(--card);transition:background var(--trans-fast), transform var(--trans-fast);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex;position:relative;overflow:hidden}.album-rail-card:hover{background:var(--card-high);transform:scale(1.03)}.album-rail-icon{font-size:1.4rem}.album-rail-title{font-family:var(--serif);color:var(--gold);text-align:center;padding:0 .5rem;font-size:.75rem;font-style:italic;line-height:1.3}.album-rail-count{font-family:var(--mono);color:var(--muted);letter-spacing:.1em;font-size:.55rem}.more-card{aspect-ratio:1;border-radius:var(--radius);border:1px dashed var(--dimmed);cursor:pointer;transition:border-color var(--trans-fast);flex-direction:column;justify-content:center;align-items:center;gap:.3rem;display:flex;position:relative}.more-card:hover{border-color:var(--gold-dim)}.more-count{font-family:var(--serif);color:var(--muted);font-size:1.1rem}.more-label{font-family:var(--mono);color:var(--dimmed);letter-spacing:.15em;text-transform:uppercase;font-size:.55rem}.music-landing{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.2rem;min-height:70vh;padding:2rem;display:flex}.music-vinyl{width:200px;height:200px;margin-bottom:.5rem;position:relative}.vinyl-disc{border:2px solid var(--border-hi);background:radial-gradient(circle at 30% 30%,#2a2535,#0f0e18 50%,#0a0912);border-radius:50%;justify-content:center;align-items:center;width:200px;height:200px;animation:4s linear infinite spin-disc;display:flex;position:relative;box-shadow:0 0 40px #c9a96e0d,inset 0 0 60px #0009}.vinyl-disc:before{content:"";border:1px solid #c9a96e0f;border-radius:50%;position:absolute;inset:12px}.vinyl-disc:after{content:"";border:1px solid #c9a96e0a;border-radius:50%;position:absolute;inset:28px}.vinyl-label{border:1px solid var(--gold-dim);z-index:1;background:radial-gradient(circle at 35% 35%,#2a2040,#1a1030);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;width:70px;height:70px;display:flex}.vinyl-heart{color:var(--rose);font-size:.6rem}.vinyl-initials{font-family:var(--serif);color:var(--gold);letter-spacing:.15em;font-size:1rem}.vinyl-arm{background:linear-gradient(90deg, var(--gold-dim), var(--gold));transform-origin:100%;opacity:.5;border-radius:2px;width:80px;height:4px;position:absolute;top:10px;right:-10px;transform:rotate(-15deg)}.vinyl-arm:after{content:"";background:radial-gradient(circle at 40% 40%, var(--gold), var(--gold-dim));border-radius:50%;width:16px;height:16px;position:absolute;top:-6px;left:-4px}@keyframes spin-disc{to{transform:rotate(360deg)}}.music-title{font-family:var(--serif);color:var(--text);font-size:2rem;font-weight:400}.music-sub{font-family:var(--body);color:var(--muted);font-size:.95rem;font-style:italic;font-weight:300;line-height:1.6}.music-notes{gap:.6rem;margin-top:.5rem;display:flex}.music-notes span{color:var(--gold-dim);opacity:.4;font-size:1.2rem;animation:3s ease-in-out infinite note-float}.music-notes span:first-child{color:var(--gold);opacity:.5;animation-delay:0s}.music-notes span:nth-child(2){animation-delay:.3s}.music-notes span:nth-child(3){color:var(--rose);opacity:.5;animation-delay:.6s}.music-notes span:nth-child(4){animation-delay:.9s}.music-notes span:nth-child(5){color:var(--gold);opacity:.5;animation-delay:1.2s}.music-notes span:nth-child(6){animation-delay:1.5s}@keyframes note-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.1)}}@media (max-width:768px){.gallery-stats-row{gap:1.2rem;padding:.75rem 1rem}.gallery-stat-val{font-size:1.2rem}.gallery-filter-bar{gap:.5rem}.month-content{grid-template-columns:1fr}.featured-photo{aspect-ratio:4/3}.photos-row{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.view-btn{padding:.4rem .65rem;font-size:.6rem}.music-vinyl,.vinyl-disc{width:150px;height:150px}.vinyl-label{width:55px;height:55px}.vinyl-initials{font-size:.8rem}.music-title{font-size:1.5rem}}#page-home:has(.inicio-scroll-wrap){flex-direction:column;height:100%;min-height:0;padding:0;display:flex;overflow:hidden}.inicio-scroll-wrap{scroll-snap-type:y mandatory;scroll-behavior:smooth;flex:1;height:100%;position:relative;overflow-y:scroll}.inicio-panel{scroll-snap-align:start;background:0 0;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.inicio-panel:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 80%,#0000 30%,#0807108c 100%);position:absolute;inset:0}.inicio-panel>*{z-index:1;position:relative}.inicio-section-tag{font-family:var(--mono);letter-spacing:.4em;text-transform:uppercase;color:var(--dimmed);z-index:5;align-items:center;gap:.75rem;font-size:.5rem;display:flex;position:absolute;top:2rem;left:3rem}.inicio-section-tag:before{content:"";background:var(--gold-dim);flex-shrink:0;width:20px;height:1px}.inicio-panel-inner{z-index:1;grid-template-columns:1fr 1.6fr;align-items:center;gap:5rem;width:100%;max-width:960px;padding:0 3rem;display:grid;position:relative}.inicio-panel-left{flex-direction:column;gap:.8rem;display:flex}.inicio-panel-right{flex-direction:column;align-items:stretch;display:flex}.inicio-scroll-cue{z-index:2;transition:opacity .5s var(--ease);flex-direction:column;align-items:center;gap:.5rem;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.inicio-scroll-cue.hidden{opacity:0;pointer-events:none}.inicio-scroll-cue-line{background:linear-gradient(to bottom, transparent, var(--gold-dim));width:1px;height:40px;animation:2s ease-in-out infinite inicioCuePulse}.inicio-scroll-cue-label{font-family:var(--mono);letter-spacing:.35em;text-transform:uppercase;color:var(--dimmed);font-size:.5rem}@keyframes inicioCuePulse{0%,to{opacity:.3}50%{opacity:1}}.inicio-dot-nav{z-index:200;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:50%;right:2rem;transform:translateY(-50%)}.inicio-dot{background:var(--dimmed);cursor:pointer;width:6px;height:6px;transition:all .4s var(--ease);border:none;border-radius:50%;padding:0}.inicio-dot.active{background:var(--gold);height:18px;box-shadow:0 0 8px color-mix(in srgb, var(--gold) 40%, transparent);border-radius:3px}.inicio-reveal{opacity:0;transition:opacity .65s var(--ease), transform .65s var(--ease);transform:translateY(20px)}.inicio-reveal.visible{opacity:1;transform:translateY(0)}.inicio-reveal:nth-child(2){transition-delay:80ms}.inicio-reveal:nth-child(3){transition-delay:.16s}.inicio-reveal:nth-child(4){transition-delay:.24s}.inicio-reveal:nth-child(5){transition-delay:.32s}.inicio-moment-card{background:var(--card);border:1px solid var(--border-hi);border-radius:var(--radius);transition:border-color var(--trans-fast), box-shadow var(--trans-fast);align-items:center;gap:1.2rem;padding:1.6rem;display:flex;position:relative;overflow:hidden}.inicio-moment-card:after{content:"";pointer-events:none;background:radial-gradient(circle at 0 100%,#c9a96e0d,#0000);width:160px;height:160px;position:absolute;bottom:0;left:0}.inicio-moment-card:hover{border-color:var(--gold);box-shadow:0 0 20px #c9a96e0f}.inicio-moment-emoji-box{border-radius:var(--radius);background:var(--card-high);border:1px solid var(--border-hi);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.8rem;display:flex}.inicio-moment-info{flex-direction:column;gap:.2rem;display:flex}.inicio-moment-tag{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.5rem}.inicio-moment-title{font-family:var(--serif);color:var(--text);font-size:1.1rem}.inicio-moment-date{font-family:var(--mono);letter-spacing:.15em;color:var(--gold);font-size:.55rem}.inicio-empty-card{border:1px solid var(--border-hi);border-radius:var(--radius);text-align:center;background:0 0;flex-direction:column;align-items:center;gap:.6rem;padding:2.5rem 2rem;display:flex}.inicio-card-link{font-family:var(--mono);letter-spacing:.1em;color:var(--gold);transition:opacity var(--trans-fast);margin-top:.4rem;font-size:.55rem}.inicio-card-link:hover{opacity:.7}.inicio-galeria-grid{border-radius:var(--radius);grid-template-rows:1fr 1fr;grid-template-columns:1.4fr 1fr;gap:.6rem;height:380px;display:grid;overflow:hidden}.inicio-galeria-grid .foto-cell:first-child{grid-row:span 2}.foto-cell{justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.foto-cell img{object-fit:cover;width:100%;height:100%;transition:transform var(--trans-med);display:block}.foto-cell:hover img{transform:scale(1.05)}.foto-cell-overlay{opacity:0;transition:opacity var(--trans-med);font-family:var(--body);color:var(--text);background:linear-gradient(#0000 50%,#00000080 100%);align-items:flex-end;padding:.8rem;font-size:.75rem;font-style:italic;display:flex;position:absolute;inset:0}.foto-cell:hover .foto-cell-overlay{opacity:1}.foto-cell.placeholder{background:var(--card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.3rem}.galeria-stats-row{align-items:center;gap:.4rem;margin-bottom:.6rem;display:flex}.stat-divider-vert{background:var(--border);width:1px;height:18px;margin:0 .3rem}.inicio-letters-stack{flex-direction:column;gap:.6rem;display:flex}.inicio-letter-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:transform var(--trans-fast), border-color var(--trans-fast);cursor:pointer;border-left:1px solid var(--border);align-items:center;gap:1rem;padding:1rem 1.2rem;display:flex}.inicio-letter-item:hover{border-color:var(--rose);border-left:3px solid var(--rose);transform:translate(4px)}.inicio-letter-item.placeholder{border-left:1px solid var(--border);border-style:dashed}.inicio-letter-item.placeholder:hover{border-color:var(--border-hi);border-left:3px solid var(--border-hi);border-style:dashed}.inicio-letter-icon{background:color-mix(in srgb, var(--rose-dim) 20%, transparent);border:1px solid #b8756a33;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.inicio-letter-body{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.inicio-letter-from{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--rose);font-size:.5rem}.inicio-letter-subject{font-family:var(--serif);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-style:italic;overflow:hidden}.inicio-letter-date{font-family:var(--mono);color:var(--dimmed);flex-shrink:0;font-size:.5rem}.inicio-capsules-list{flex-direction:column;gap:.75rem;display:flex}.inicio-capsule-card{background:var(--card);border:1px solid var(--border-hi);border-radius:var(--radius);transition:transform var(--trans-fast), border-color var(--trans-fast);cursor:pointer;flex-direction:column;gap:.2rem;padding:1.2rem 1.5rem;display:flex;position:relative;overflow:hidden}.inicio-capsule-card:hover{border-color:var(--gold);transform:translateY(-2px)}.inicio-capsule-card.placeholder{cursor:pointer;border-style:dashed}.inicio-capsule-ornament{opacity:.15;transition:opacity var(--trans-fast);pointer-events:none;font-size:1.5rem;position:absolute;top:.5rem;right:.8rem}.inicio-capsule-card:hover .inicio-capsule-ornament{opacity:.45}.inicio-capsule-meta{font-family:var(--mono);letter-spacing:.1em;color:var(--gold);font-size:.5rem}.inicio-capsule-title{font-family:var(--serif);color:var(--text);font-size:.95rem;font-style:italic}.inicio-capsule-date{font-family:var(--mono);color:var(--dimmed);margin-top:.1rem;font-size:.5rem}.skeleton{background:var(--card);border-radius:var(--radius);position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff0a 50%,#0000 100%);animation:1.6s ease-in-out infinite skeletonShimmer;position:absolute;inset:0}@keyframes skeletonShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.inicio-wish-wrap{flex-direction:column;gap:.6rem;display:flex}.inicio-wish-text{font-family:var(--serif);color:var(--muted);font-size:.85rem;font-style:italic;line-height:1.5}.inicio-wish-wrap .missyou-area{background:0 0;border:none;gap:.8rem;padding:0}.inicio-wish-wrap .missyou-text h3{font-size:.85rem}.inicio-wish-wrap .missyou-text p{font-size:.5rem}@media (max-width:768px){.inicio-panel-inner{grid-template-columns:1fr;gap:2rem;max-height:90vh;padding:0 1.5rem;overflow-y:auto}.inicio-panel-left{gap:.8rem}.inicio-galeria-grid{height:260px}.inicio-dot-nav{display:none}.inicio-section-tag{top:1.5rem;left:1.5rem}.inicio-panel-left .inicio-reveal:nth-child(3){font-size:1rem}}.login-page{z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative}.login-page:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(70% 70%,#0000 20%,#080710a6 100%);position:absolute;inset:0}.login-card{z-index:1;background:var(--card);border:1px solid var(--border-hi);border-radius:18px;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:420px;padding:3rem 2.5rem 2.5rem;animation:.9s cubic-bezier(.16,1,.3,1) both loginCardEnter;display:flex;position:relative;box-shadow:0 0 0 1px #c9a96e0a,0 32px 64px #08071099,inset 0 1px #ffffff0a}@keyframes loginCardEnter{0%{opacity:0;transform:translateY(24px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.login-card:before{content:"";pointer-events:none;background:radial-gradient(60% 40% at 0 100%,#c9a96e0d 0%,#0000 60%);border-radius:18px;position:absolute;inset:0}.login-card-header{flex-direction:column;align-items:center;gap:.5rem;display:flex}.login-ornament{color:var(--gold);filter:drop-shadow(0 0 10px color-mix(in srgb, var(--gold) 40%, transparent));font-size:1.2rem;animation:.9s cubic-bezier(.16,1,.3,1) .1s both loginCardEnter}.login-app-title{font-family:var(--serif);color:var(--text);font-size:1.8rem;font-weight:400;animation:.9s cubic-bezier(.16,1,.3,1) .2s both loginCardEnter}.login-app-title em{color:var(--text);font-style:italic}.login-tagline{font-family:var(--mono);letter-spacing:.4em;text-transform:uppercase;color:var(--muted);font-size:.55rem;animation:.9s cubic-bezier(.16,1,.3,1) .3s both loginCardEnter}.login-form{flex-direction:column;gap:1rem;width:100%;display:flex}.login-field{flex-direction:column;gap:.4rem;width:100%;display:flex}.login-label{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-size:.55rem}.login-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--body);color:var(--text);transition:border-color .2s var(--ease), box-shadow .2s var(--ease);caret-color:var(--gold);outline:none;padding:.75rem 1rem;font-size:.9rem}.login-input::placeholder{color:var(--dimmed);font-style:italic}.login-input:focus{border-color:var(--border-hi);box-shadow:0 0 0 3px #c9a96e14}.login-input-line{background:linear-gradient(to right, var(--gold-dim), transparent);transform-origin:0;height:1px;transition:transform .35s var(--ease);margin-top:-1px;transform:scaleX(0)}.login-input:focus~.login-input-line{transform:scaleX(1)}.login-eye-btn{cursor:pointer;color:var(--dimmed);background:0 0;border:none;align-items:center;padding:.25rem;transition:color .2s;display:flex;position:absolute;top:50%;right:.85rem;transform:translateY(-50%)}.login-eye-btn:hover{color:var(--muted)}.login-btn{background:var(--gold);color:#080710;border-radius:var(--radius);width:100%;font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;cursor:pointer;transition:background .2s var(--ease), transform .15s var(--ease), box-shadow .2s;border:none;margin-top:.5rem;padding:.8rem 1rem;font-size:.7rem;position:relative;overflow:hidden}.login-btn:hover{background:#d9b87e;transform:translateY(-1px);box-shadow:0 8px 24px #c9a96e33}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-spinner{border:2px solid #08071033;border-top-color:#080710;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite loginSpin;display:inline-block}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-error{font-family:var(--mono);color:var(--rose);text-align:center;letter-spacing:.05em;border-radius:var(--radius);animation:loginErrorShake .4s var(--ease);background:#b8707014;border:1px solid #b8707033;padding:.6rem 1rem;font-size:.62rem}@keyframes loginErrorShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-footer-text{font-family:var(--mono);letter-spacing:.25em;color:var(--dimmed);text-align:center;margin-top:.5rem;font-size:.5rem}@media (max-width:480px){.login-card{border-radius:14px;max-width:100%;padding:2.5rem 1.5rem 2rem}.login-app-title{font-size:1.5rem}}.cartas-layout{grid-template-columns:340px 1fr;gap:0;height:100%;display:grid;overflow:hidden}.cartas-sidebar{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;display:flex;overflow:hidden}.cartas-sidebar-header{background:var(--bg);z-index:10;border-bottom:1px solid var(--border);flex-direction:column;gap:1.2rem;padding:1.5rem 1.25rem 1rem;display:flex;position:sticky;top:0}.cartas-sidebar-title-row{justify-content:space-between;align-items:center;display:flex}.cartas-sidebar-title{font-family:var(--serif);color:var(--gold);font-size:1.3rem;font-style:italic;font-weight:400}.cartas-new-btn{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s var(--ease);background:0 0;padding:.3rem .7rem;font-size:.62rem}.cartas-new-btn:hover{color:var(--text);border-color:var(--border-hi);background:#c9a96e0f}.cartas-search{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--mono);color:var(--text);transition:border-color .15s var(--ease);box-sizing:border-box;outline:none;padding:.6rem .8rem;font-size:.72rem}.cartas-search::placeholder{color:var(--dimmed);font-style:italic}.cartas-search:focus{border-color:var(--border-hi)}.cartas-tabs{gap:.25rem;display:flex}.cartas-tab{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-radius:var(--radius);cursor:pointer;text-align:center;transition:all .2s var(--ease);white-space:nowrap;background:0 0;border:1px solid #0000;flex:1;padding:.35rem .5rem;font-size:.58rem}.cartas-tab:hover{color:var(--text);border-color:var(--border)}.cartas-tab.active{color:var(--gold);background:var(--card);border-color:var(--border-hi)}.cartas-tab-badge{background:var(--rose);color:#080710;width:16px;height:16px;font-size:.45rem;font-family:var(--mono);vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;margin-left:.3rem;display:inline-flex}.cartas-list{flex-direction:column;flex:1;display:flex;overflow-y:auto}.cartas-list-item{cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s var(--ease);flex-direction:column;gap:.3rem;padding:1rem 1.25rem;display:flex;position:relative}.cartas-list-item:hover{background:var(--surface)}.cartas-list-item.selected{background:var(--card);border-left:2px solid var(--gold);padding-left:calc(1.25rem - 2px)}.cartas-list-item-top{justify-content:space-between;align-items:center;display:flex}.cartas-list-from{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-size:.52rem}.cartas-list-indicators{align-items:center;gap:.3rem;display:flex}.mood-dot{opacity:.8;border-radius:50%;flex-shrink:0;width:6px;height:6px}.cartas-unread-dot{background:var(--rose);border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.cartas-list-subject{font-family:var(--serif);color:var(--text);font-size:.92rem;font-style:italic;font-weight:400;line-height:1.3}.cartas-list-subject.unread{font-weight:500}.cartas-list-preview{font-family:var(--body);color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;line-height:1.4;overflow:hidden}.cartas-list-date{font-family:var(--mono);color:var(--dimmed);letter-spacing:.05em;font-size:.52rem}.cartas-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.6rem;padding:3rem 2rem;display:flex}.cartas-empty-icon{opacity:.5;margin-bottom:.3rem;font-size:2rem}.cartas-empty-title{font-family:var(--serif);color:var(--muted);font-size:1rem;font-style:italic}.cartas-empty-sub{font-family:var(--mono);color:var(--dimmed);letter-spacing:.08em;font-size:.55rem}.cartas-reader{flex-direction:column;flex:1;align-items:center;display:flex;position:relative;overflow-y:auto}.cartas-reader-back{font-family:var(--mono);color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;align-self:flex-start;padding:1rem 1.5rem 0;font-size:.65rem;display:none}.cartas-reader-back:hover{color:var(--gold)}.cartas-reader-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.8rem;display:flex}.cartas-reader-empty-icon{color:var(--gold);opacity:.5;text-shadow:0 0 30px #c9a96e33;font-size:3rem}.cartas-reader-empty-title{font-family:var(--serif);color:var(--muted);font-size:1.1rem;font-style:italic}.cartas-reader-empty-sub{font-family:var(--mono);color:var(--dimmed);letter-spacing:.1em;font-size:.6rem}.cartas-reader-content{width:100%;max-width:640px;animation:cartasReaderEnter .35s var(--ease) both;padding:3rem 2rem}@keyframes cartasReaderEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cartas-reader-header{border-bottom:1px solid var(--border);flex-direction:column;gap:.6rem;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}.cartas-mood-pill{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid;border-radius:20px;align-items:center;gap:.4rem;width:fit-content;padding:.2rem .65rem;font-size:.55rem;display:inline-flex}.cartas-reader-fromto{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--gold);font-size:.6rem}.cartas-reader-subject{font-family:var(--serif);color:var(--text);font-size:2rem;font-weight:400;line-height:1.2}.cartas-reader-subject.unread{border-left:3px solid var(--rose);padding-left:.75rem}.cartas-reader-date{font-family:var(--mono);color:var(--muted);letter-spacing:.1em;font-size:.6rem}.cartas-reader-actions{gap:.6rem;margin-top:.25rem;display:flex}.cartas-reader-btn{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s var(--ease);background:0 0;padding:.3rem .7rem;font-size:.6rem}.cartas-reader-btn:hover{color:var(--text);border-color:var(--border-hi)}.cartas-reader-btn--del{color:var(--rose-dim);border-color:#b8756a4d}.cartas-reader-btn--del:hover{color:var(--rose);border-color:var(--rose-dim);background:#b8756a0f}.cartas-reader-body{font-family:var(--body);color:#ede8dad9;font-size:1rem;line-height:2}.cartas-reader-body p{margin-bottom:1.2em}.cartas-reader-sig{font-family:var(--serif);color:var(--gold);text-align:right;margin-top:2rem;font-size:1.3rem;font-style:italic}.cartas-composer-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:500;animation:cartasOverlayIn .3s var(--ease) both;background:#080710d9;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}@keyframes cartasOverlayIn{0%{opacity:0}to{opacity:1}}.cartas-composer{background:var(--surface);border:1px solid var(--border-hi);width:min(620px,96vw);max-height:90vh;animation:cartasComposerIn .4s var(--ease) both;border-radius:16px;flex-direction:column;gap:1.5rem;padding:2.5rem;display:flex;overflow-y:auto}@keyframes cartasComposerIn{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.cartas-composer-header{justify-content:space-between;align-items:center;display:flex}.cartas-composer-header-title{font-family:var(--serif);color:var(--gold);font-size:1.2rem;font-style:italic}.cartas-composer-close{color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;font-size:1.5rem;line-height:1}.cartas-composer-close:hover{color:var(--text)}.cartas-composer-fields{flex-direction:column;gap:1.2rem;display:flex}.cartas-composer-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.cartas-composer-field{flex-direction:column;gap:.4rem;display:flex}.cartas-composer-label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.55rem}.cartas-composer-input{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--body);color:var(--text);transition:border-color .15s var(--ease);box-sizing:border-box;outline:none;width:100%;padding:.5rem .75rem;font-size:.85rem}.cartas-composer-input:focus{border-color:var(--border-hi)}.cartas-composer-input[readonly]{opacity:.7;color:var(--gold)}.cartas-composer-input-row{gap:.4rem;display:flex}.cartas-composer-input-row .cartas-composer-input{flex:1}.cartas-composer-quickfill{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer;transition:all .15s var(--ease);flex-shrink:0;padding:.5rem .6rem;font-size:.85rem}.cartas-composer-quickfill:hover{border-color:var(--border-hi);color:var(--text)}.composer-mood-row{flex-wrap:wrap;gap:.5rem;display:flex}.composer-mood-pill{border:1px solid var(--border);font-family:var(--mono);letter-spacing:.05em;cursor:pointer;transition:all .15s var(--ease);color:var(--muted);background:0 0;border-radius:20px;align-items:center;gap:.3rem;padding:.3rem .7rem;font-size:.58rem;display:flex}.composer-mood-pill:hover{border-color:var(--border-hi);color:var(--text)}.composer-mood-pill.active{background:#c9a96e1a}.cartas-composer-textarea{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--body);color:var(--text);resize:vertical;min-height:260px;transition:border-color .15s var(--ease);outline:none;padding:.7rem .85rem;font-size:.95rem;line-height:1.9}.cartas-composer-textarea:focus{border-color:var(--border-hi)}.cartas-composer-textarea::placeholder{color:var(--dimmed);font-style:italic}.cartas-composer-charcount{font-family:var(--mono);color:var(--dimmed);text-align:right;margin-top:.2rem;font-size:.52rem}.cartas-composer-divider{background:var(--border);height:1px}.cartas-composer-actions{justify-content:flex-end;gap:.75rem;display:flex}@media (max-width:768px){.cartas-layout{grid-template-rows:1fr;grid-template-columns:1fr;height:100%;min-height:0}.cartas-sidebar{border-right:none;border-bottom:1px solid var(--border);overflow-y:auto}.cartas-reader,.cartas-layout.letter-open .cartas-sidebar{display:none}.cartas-layout.letter-open .cartas-reader,.cartas-reader-back{display:flex}.cartas-reader-content{padding:2rem 1.25rem}.cartas-reader-subject{font-size:1.5rem}.cartas-reader-body{font-size:.9rem}.cartas-composer{padding:1.5rem}.cartas-composer-row{grid-template-columns:1fr}.composer-mood-pill{padding:.25rem .55rem;font-size:.52rem}.cartas-tabs{overflow-x:auto}}.peliculas-page{max-width:1100px;margin:0 auto;padding:2rem 2.5rem}.peliculas-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:1.5rem;display:flex}.peliculas-subtitle{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem;font-size:.55rem}.peliculas-title{font-family:var(--serif);color:var(--text);font-size:2rem;font-weight:400;line-height:1.1}.peliculas-title em{color:var(--gold);font-style:italic}.peliculas-header-right{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.peliculas-stats-row{gap:.75rem;display:flex}.peliculas-stat-pill{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:.1rem;min-width:56px;padding:.35rem .6rem;display:flex}.peliculas-stat-val{font-family:var(--serif);color:var(--text);font-size:1rem;font-weight:400;line-height:1}.peliculas-stat-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.48rem}.peliculas-filters{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.peliculas-filter-chips{flex-wrap:wrap;gap:.3rem;display:flex}.peliculas-chip{border:1px solid var(--border);font-family:var(--mono);letter-spacing:.05em;color:var(--muted);cursor:pointer;transition:all .15s var(--ease);background:0 0;border-radius:6px;padding:.25rem .6rem;font-size:.55rem}.peliculas-chip:hover{border-color:var(--border-hi);color:var(--text)}.peliculas-chip.active{border-color:var(--gold);color:var(--gold);background:#c9a96e1a}.peliculas-select{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--mono);color:var(--text);cursor:pointer;outline:none;padding:.35rem .6rem;font-size:.58rem}.peliculas-select:focus{border-color:var(--border-hi)}.peliculas-stats-toggle{font-family:var(--mono);letter-spacing:.08em;color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;margin-bottom:.75rem;padding:.4rem 0;font-size:.58rem;display:block}.peliculas-stats-toggle:hover{color:var(--gold)}.peliculas-stat-panel{animation:slide-up .25s var(--ease);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.peliculas-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.25rem;padding:1rem 1.25rem;display:flex}.peliculas-stat-card-val{font-family:var(--serif);color:var(--text);font-size:.95rem;font-weight:400}.peliculas-stat-card-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--dimmed);font-size:.48rem}.peliculas-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.25rem;display:grid}.pelicula-card{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:transform .3s var(--ease), border-color .25s;aspect-ratio:2/3;background:var(--card);position:relative;overflow:hidden}.pelicula-card:hover{border-color:var(--border-hi);transform:translateY(-4px)scale(1.02)}.pelicula-card img{object-fit:cover;width:100%;height:100%;display:block}.pelicula-poster-placeholder{background:var(--card);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;height:100%;display:flex}.pelicula-poster-placeholder-title{font-family:var(--serif);color:var(--muted);text-align:center;padding:0 .5rem;font-size:.75rem;font-style:italic;line-height:1.2}.pelicula-rating-badge{font-family:var(--mono);letter-spacing:.05em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:5px;padding:.2rem .5rem;font-size:.6rem;font-weight:600;position:absolute;top:.5rem;right:.5rem}.pelicula-unrated-dot{background:var(--rose);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot;position:absolute;top:.5rem;left:.5rem}@keyframes pulse-dot{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.pelicula-card-overlay{opacity:0;transition:opacity .25s var(--ease);background:linear-gradient(#0000 0%,#08071033 40%,#080710eb 100%);flex-direction:column;justify-content:flex-end;gap:.3rem;padding:1rem .85rem;display:flex;position:absolute;inset:0}.pelicula-card:hover .pelicula-card-overlay{opacity:1}.pelicula-card-overlay-title{font-family:var(--serif);color:var(--text);font-size:.85rem;font-weight:400;line-height:1.2}.pelicula-card-overlay-meta{font-family:var(--mono);color:var(--muted);font-size:.55rem}.pelicula-card-overlay-genres{flex-wrap:wrap;gap:.3rem;margin-top:.2rem;display:flex}.pelicula-genre-tag{font-family:var(--mono);letter-spacing:.05em;color:var(--gold-dim);background:#c9a96e1a;border-radius:4px;padding:.1rem .4rem;font-size:.48rem;display:inline-block}.pelicula-card-overlay-notes{font-family:var(--body);color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.15rem;font-size:.6rem;font-style:italic;line-height:1.4;display:-webkit-box;overflow:hidden}.peliculas-list{flex-direction:column;gap:.6rem;display:flex}.pelicula-list-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .2s, transform .2s var(--ease);grid-template-columns:54px 1fr auto;align-items:center;gap:1.25rem;padding:1rem 1.25rem;display:grid}.pelicula-list-item:hover{border-color:var(--border-hi);transform:translate(3px)}.pelicula-list-thumb{background:var(--surface);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:80px;font-size:1.3rem;display:flex;overflow:hidden}.pelicula-list-img{object-fit:cover;width:100%;height:100%}.pelicula-list-placeholder{font-size:1.3rem}.pelicula-list-info{flex-direction:column;gap:.2rem;min-width:0;display:flex}.pelicula-list-title{font-family:var(--serif);color:var(--text);font-size:.95rem;font-style:italic}.pelicula-list-meta{font-family:var(--mono);color:var(--muted);font-size:.52rem}.pelicula-list-genres{flex-wrap:wrap;gap:.3rem;margin-top:.15rem;display:flex}.pelicula-list-notes{font-family:var(--body);color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:.1rem;font-size:.68rem;font-style:italic;line-height:1.3;overflow:hidden}.pelicula-list-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.3rem;display:flex}.pelicula-list-date{font-family:var(--mono);color:var(--dimmed);letter-spacing:.05em;font-size:.48rem}.peliculas-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.8rem;padding:4rem 2rem;display:flex}.peliculas-empty-icon{opacity:.5;font-size:2.5rem}.peliculas-empty-text{font-family:var(--serif);color:var(--muted);font-size:1rem;font-style:italic}.pelicula-search-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:500;animation:cartasOverlayIn .3s var(--ease) both;background:#080710d9;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.pelicula-search-panel{background:var(--surface);border:1px solid var(--border-hi);width:min(620px,96vw);max-height:88vh;animation:cartasComposerIn .4s var(--ease) both;border-radius:16px;flex-direction:column;gap:1rem;padding:2rem;display:flex;overflow-y:auto}.pelicula-search-header{align-items:center;gap:.75rem;display:flex}.pelicula-search-input{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--serif);color:var(--text);transition:border-color .15s var(--ease);outline:none;flex:1;padding:.7rem .9rem;font-size:1.1rem;font-style:italic}.pelicula-search-input:focus{border-color:var(--border-hi)}.pelicula-search-input::placeholder{color:var(--dimmed);font-style:italic}.pelicula-search-close{color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;flex-shrink:0;font-size:1.5rem;line-height:1}.pelicula-search-close:hover{color:var(--text)}.pelicula-search-hint{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--dimmed);font-size:.5rem}.pelicula-search-results{flex-direction:column;gap:.5rem;min-height:100px;display:flex}.pelicula-search-prompt{text-align:center;color:var(--muted);font-family:var(--serif);flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:2.5rem 1rem;font-size:.9rem;font-style:italic;display:flex}.pelicula-search-prompt-icon{opacity:.4;font-size:2rem}.pelicula-search-skeletons{flex-direction:column;gap:.75rem;display:flex}.tmdb-skeleton-row{border-radius:var(--radius);height:60px}.tmdb-result-item{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;grid-template-columns:48px 1fr auto;align-items:center;gap:1rem;padding:.85rem 1rem;transition:background .15s;display:grid}.tmdb-result-item:hover{background:var(--card);border-color:var(--border)}.tmdb-result-item.already-added{opacity:.5;cursor:default;pointer-events:none}.tmdb-result-poster{background:var(--card);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:72px;font-size:1.2rem;display:flex;overflow:hidden}.tmdb-result-poster img{object-fit:cover;width:100%;height:100%}.tmdb-result-info{flex-direction:column;gap:.15rem;min-width:0;display:flex}.tmdb-result-title{font-family:var(--serif);color:var(--text);font-size:.95rem;font-style:italic}.tmdb-result-meta{font-family:var(--mono);color:var(--muted);font-size:.5rem}.tmdb-result-overview{font-family:var(--body);color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.72rem;line-height:1.4;display:-webkit-box;overflow:hidden}.tmdb-result-badge{font-family:var(--mono);letter-spacing:.08em;color:var(--gold-dim);border:1px solid var(--gold-dim);white-space:nowrap;border-radius:4px;padding:.2rem .5rem;font-size:.5rem}.tmdb-result-add{font-family:var(--mono);letter-spacing:.1em;color:var(--gold);white-space:nowrap;font-size:.55rem}.pelicula-search-back{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;align-self:flex-start;margin-bottom:.5rem;padding:0;font-size:.6rem}.pelicula-search-back:hover{color:var(--gold)}.pelicula-detail-form{grid-template-columns:180px 1fr;gap:1.5rem;display:grid}.pelicula-detail-poster{border-radius:var(--radius);height:fit-content;overflow:hidden}.pelicula-detail-poster img{border-radius:var(--radius);width:100%;display:block}.pelicula-detail-poster-placeholder{aspect-ratio:2/3;background:var(--card);border-radius:var(--radius);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.pelicula-detail-info{flex-direction:column;gap:1.25rem;display:flex}.pelicula-detail-title{font-family:var(--serif);color:var(--text);font-size:1.4rem;font-weight:400;line-height:1.2}.pelicula-detail-meta{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;font-size:.58rem}.pelicula-detail-overview{font-family:var(--body);color:var(--muted);-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:.78rem;font-style:italic;line-height:1.6;display:-webkit-box;overflow:hidden}.pelicula-detail-field{flex-direction:column;gap:.4rem;display:flex}.pelicula-detail-label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.52rem}.rating-pill-row{gap:.4rem;display:flex}.rating-pill{border:1px solid var(--border);font-family:var(--mono);cursor:pointer;text-align:center;transition:all .2s var(--ease);color:var(--muted);background:0 0;border-radius:8px;flex:1;padding:.6rem .4rem;font-size:.8rem;font-weight:700}.rating-pill:hover{border-color:var(--border-hi)}.rating-pill.selected{transform:scale(1.06)}.pelicula-detail-input{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--body);color:var(--text);transition:border-color .15s var(--ease);outline:none;padding:.5rem .75rem;font-size:.85rem}.pelicula-detail-input:focus{border-color:var(--border-hi)}.pelicula-addedby-row{gap:.5rem;display:flex}.pelicula-addedby-pill{border:1px solid var(--border);font-family:var(--mono);letter-spacing:.08em;cursor:pointer;color:var(--muted);transition:all .15s var(--ease);background:0 0;border-radius:20px;padding:.35rem .8rem;font-size:.6rem}.pelicula-addedby-pill:hover{border-color:var(--border-hi);color:var(--text)}.pelicula-addedby-pill.active{border-color:var(--gold);color:var(--gold);background:#c9a96e1a}.pelicula-detail-textarea{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--body);color:var(--text);resize:vertical;min-height:100px;transition:border-color .15s var(--ease);outline:none;padding:.6rem .8rem;font-size:.78rem;line-height:1.6}.pelicula-detail-textarea:focus{border-color:var(--border-hi)}.pelicula-detail-textarea::placeholder{color:var(--dimmed);font-style:italic}.pelicula-detail-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.pelicula-modal{background:var(--surface);border:1px solid var(--border-hi);width:min(700px,94vw);max-height:88vh;animation:cartasComposerIn .4s var(--ease) both;border-radius:16px;padding:2rem;position:relative;overflow-y:auto}.pelicula-modal-inner{grid-template-columns:200px 1fr;gap:2rem;display:grid}.pelicula-modal-poster{border-radius:var(--radius);overflow:hidden}.pelicula-modal-poster img{width:100%;display:block}.pelicula-modal-details{flex-direction:column;gap:.6rem;display:flex}.pelicula-modal-title{font-family:var(--serif);color:var(--text);font-size:1.8rem;font-weight:400;line-height:1.15}.pelicula-modal-year{font-family:var(--mono);color:var(--muted);letter-spacing:.1em;font-size:.6rem}.pelicula-modal-meta{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;font-size:.55rem}.pelicula-modal-genres{flex-wrap:wrap;gap:.3rem;margin-top:.2rem;display:flex}.pelicula-modal-overview{font-family:var(--body);color:var(--muted);margin-top:.3rem;font-size:.82rem;font-style:italic;line-height:1.8}.pelicula-modal-rating{flex-direction:column;align-items:center;gap:.3rem;margin-top:.5rem;padding:1rem 0;display:flex}.pelicula-modal-rating-pill{font-family:var(--mono);border:2px solid;border-radius:12px;padding:.4rem 1.2rem;font-size:2rem;font-weight:700;display:inline-block}.pelicula-modal-rating-label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--dimmed);font-size:.5rem}.pelicula-modal-notes{font-family:var(--body);color:var(--text);margin-top:.3rem;font-size:.85rem;font-style:italic;line-height:1.6}.pelicula-modal-notes-prefix{margin-right:.3rem}.pelicula-modal-notes-empty{font-family:var(--serif);color:var(--dimmed);margin-top:.3rem;font-size:.75rem;font-style:italic}.pelicula-modal-watched{font-family:var(--mono);color:var(--dimmed);letter-spacing:.05em;margin-top:.3rem;font-size:.55rem}.pelicula-modal-tmdb{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;font-size:.52rem}.pelicula-modal-edit{border-top:1px solid var(--border);flex-direction:column;gap:1rem;margin-top:.5rem;padding-top:1rem;display:flex}.pelicula-modal-edit-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.pelicula-modal-actions{border-top:1px solid var(--border);gap:.6rem;margin-top:1rem;padding-top:1rem;display:flex}@media (max-width:768px){.peliculas-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.pelicula-modal-inner{grid-template-columns:1fr}.pelicula-modal-poster{width:100%;height:220px}.pelicula-modal-poster img{object-fit:cover;height:100%}.peliculas-header{flex-direction:column;align-items:flex-start;gap:1rem}.pelicula-detail-form{grid-template-columns:1fr}.rating-pill{padding:.5rem .25rem;font-size:.65rem}.peliculas-page{padding:1.25rem 1rem}}.toast-container{z-index:9000;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:2rem;right:2rem}.toast-item{pointer-events:all;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);min-width:280px;max-width:380px;animation:toastEnter .35s var(--ease) both;will-change:transform, opacity;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #08071080}.toast-item.exiting{animation:toastExit .35s var(--ease) forwards}@keyframes toastEnter{0%{opacity:0;transform:translate(20px)scale(.97)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toastExit{0%{opacity:1;max-height:80px;margin-bottom:.5rem;transform:translate(0)scale(1)}to{opacity:0;max-height:0;margin-bottom:0;transform:translate(20px)scale(.96)}}.toast-accent{border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.toast-icon{width:16px;height:16px;font-size:.55rem;font-family:var(--mono);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:.1rem;display:flex}.toast-message{font-family:var(--body);color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:.82rem;line-height:1.5;display:-webkit-box;overflow:hidden}.toast-dismiss{color:var(--dimmed);transition:color var(--trans-fast);padding:.15rem;font-size:.85rem;line-height:1;position:absolute;top:.25rem;right:.4rem}.toast-dismiss:hover{color:var(--muted)}.toast-progress{border-radius:0 0 var(--radius) var(--radius);height:2px;position:absolute;bottom:0;left:0}@keyframes toastProgress{0%{width:100%}to{width:0%}}.loading-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:8000;pointer-events:all;animation:loadingFadeIn .2s var(--ease) both;background:#080710bf;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;display:flex;position:fixed;inset:0}@keyframes loadingFadeIn{0%{opacity:0}to{opacity:1}}.loading-orbit{width:48px;height:48px;position:relative}.loading-orbit-center{background:var(--gold);width:5px;height:5px;box-shadow:0 0 10px var(--gold);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-orbit-ring{border:1px solid #c9a96e26;border-radius:50%;position:absolute;inset:0}.loading-orbit-dot{transform-origin:0 0;border-radius:50%;width:7px;height:7px;position:absolute;top:50%;left:50%}.loading-orbit-dot--gold{background:var(--gold);margin:-3.5px 0 0 14px;animation:1.4s linear infinite orbitGold;box-shadow:0 0 8px #c9a96e99}.loading-orbit-dot--rose{background:var(--rose);margin:-3px 0 0 19px;animation:1.9s linear infinite orbitRose;box-shadow:0 0 6px #b8707080}@keyframes orbitGold{0%{transform:rotate(0)translate(-14px)}to{transform:rotate(360deg)translate(-14px)}}@keyframes orbitRose{0%{transform:rotate(180deg)translate(-19px)}to{transform:rotate(540deg)translate(-19px)}}.loading-message{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-size:.62rem;animation:1.5s ease-in-out infinite loadingPulse}@keyframes loadingPulse{0%,to{opacity:.5}50%{opacity:1}}.error-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;padding:2rem;display:flex;position:relative}.error-page:before{content:"";pointer-events:none;background:radial-gradient(60% 60%,#0000 20%,#080710b3 100%);position:absolute;inset:0}.error-ornament{font-family:var(--serif);color:var(--gold);opacity:.5;filter:drop-shadow(0 0 12px #c9a96e4d);font-size:1.5rem}.error-eyebrow{font-family:var(--mono);letter-spacing:.5em;text-transform:uppercase;color:var(--dimmed);margin-top:-.5rem;font-size:.55rem}.error-title{font-family:var(--serif);color:var(--gold);font-size:clamp(2rem,5vw,2.8rem);font-style:italic;font-weight:400;line-height:1.1}.error-message{font-family:var(--body);color:var(--muted);max-width:440px;font-size:1rem;font-style:italic;line-height:1.7}.error-sep{background:var(--gold-dim,#6b5228);width:40px;height:1px}.error-actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:.5rem;display:flex}.route-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.2rem;min-height:50vh;padding:4rem 2rem;display:flex}.error-stagger{animation:fadeSlideUp .45s var(--ease) both}
