@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Righteous&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--color-text: #333;--color-text-muted: #888;--color-bg: linear-gradient(135deg, #f5eaed 0%, #eddce0 30%, #f3e6e9 60%, #ebe0e3 100%);--color-surface: white;--color-accent: #7a2e3f;--color-accent-dark: #5c1e2e;--color-accent-light: #8b3a4a;--color-border: #ddd;--color-border-accent: rgba(122, 46, 63, .2);--color-overlay: rgba(0, 0, 0, .4);--color-shadow: rgba(0, 0, 0, .1);--color-btn-bg: rgba(255, 255, 255, .9);--color-input-bg: white;--color-placeholder: #bbb}[data-theme=dark]{--color-text: #e0d6d8;--color-text-muted: #998a8e;--color-bg: linear-gradient(135deg, #1a1214 0%, #201618 30%, #1e1416 60%, #1a1113 100%);--color-surface: #2a1e22;--color-accent: #c4788a;--color-accent-dark: #a85c6e;--color-accent-light: #d4919f;--color-border: #3d2a30;--color-border-accent: rgba(196, 120, 138, .3);--color-overlay: rgba(0, 0, 0, .6);--color-shadow: rgba(0, 0, 0, .3);--color-btn-bg: rgba(42, 30, 34, .9);--color-input-bg: #1e1416;--color-placeholder: #665558}:root{color:var(--color-text);background:var(--color-bg);background-attachment:fixed}body{margin:0;min-height:100vh;transition:background .3s,color .3s;-webkit-tap-highlight-color:transparent}@media(max-width:640px){:root{background-attachment:scroll}input,select,textarea{font-size:16px!important}}#root{min-height:100vh}::selection{background:var(--color-accent);color:#fff}.avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-accent);color:#fff;font-size:.75rem;font-weight:600;flex-shrink:0;text-transform:uppercase}.loading-container{display:flex;align-items:center;justify-content:center}.loading-fullpage{min-height:100vh;background:#7a2e3f}[data-theme=dark] .loading-fullpage{background:#2a1018}.loading-inline{padding:48px 0}.loading-wrapper{position:relative}.loading-svg{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.loading-path{fill:none;stroke:#ffffffd9;stroke-miterlimit:10;stroke-width:4px;stroke-dasharray:1;stroke-dashoffset:1;animation:loading-draw 1.5s linear forwards}@keyframes loading-draw{to{stroke-dashoffset:0}}.loading-text{color:#fff;font-size:2.5rem;font-weight:600;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0;font-variant-numeric:tabular-nums}.dashboard{max-width:800px;margin:0 auto;padding:80px 20px 40px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.dashboard-header h1{font-family:Righteous,Arial,sans-serif;font-size:1.8rem;color:#fff;margin:0}.dashboard-add-btn{padding:10px 24px;font-size:.9rem;font-weight:600;color:#7a2e3f;background:#ffffffe6;border:none;border-radius:20px;cursor:pointer;transition:all .2s}.dashboard-add-btn:hover{background:#fff}.dashboard-create{background:var(--color-surface);border-radius:12px;padding:24px;margin-bottom:32px;box-shadow:0 4px 20px var(--color-shadow);display:flex;flex-direction:column;gap:16px}.dashboard-input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--color-border);border-radius:8px;outline:none;font-family:inherit;box-sizing:border-box;background:var(--color-input-bg);color:var(--color-text);transition:border-color .2s}.dashboard-input:focus{border-color:var(--color-accent)}.theme-selector{display:flex;gap:8px;flex-wrap:wrap}.theme-chip{padding:8px 16px;font-size:.85rem;border:2px solid transparent;border-radius:20px;cursor:pointer;transition:all .2s;color:#fff;font-weight:500}.theme-chip.active{border-color:var(--color-text);box-shadow:0 2px 10px var(--color-shadow)}.theme-preview-bordeaux{background:#7a2e3f}.theme-preview-ocean{background:#1e6091}.theme-preview-forest{background:#27694a}.theme-preview-sunset{background:#c0582a}.theme-preview-lavender{background:#6c3483}.dashboard-create-btn{align-self:flex-start;padding:10px 28px;font-size:.9rem;font-weight:600;color:#fff;background:var(--color-accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s}.dashboard-create-btn:hover{background:var(--color-accent-dark)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.dashboard-card{position:relative;border-radius:12px;padding:28px 24px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px var(--color-shadow);min-height:120px;display:flex;align-items:flex-end}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px var(--color-shadow)}.card-content{flex:1}.dashboard-card h2{font-family:Righteous,Arial,sans-serif;font-size:1.2rem;color:#fff;margin:0 0 4px}.card-theme{font-size:.75rem;color:#ffffffb3;text-transform:capitalize}.card-action{position:absolute;top:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0000004d;color:#fff;border:none;border-radius:50%;cursor:pointer;opacity:0;transition:opacity .2s}.dashboard-card:hover .card-action{opacity:1}.card-share{right:42px}.card-share:hover{background:#00000080}.card-delete{right:8px;font-size:1.2rem}.card-delete:hover{background:#c0392bcc}.dashboard-section-title{font-family:Righteous,Arial,sans-serif;font-size:1.1rem;color:#ffffffb3;margin:32px 0 16px;font-weight:500}.share-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.share-dialog{background:var(--color-surface);border-radius:16px;padding:28px;width:100%;max-width:400px;box-shadow:0 20px 60px var(--color-shadow)}.share-dialog h3{font-family:Righteous,Arial,sans-serif;font-size:1.2rem;color:var(--color-text);margin:0 0 20px}.share-add-row{display:flex;gap:8px;margin-bottom:16px}.share-select{flex:1;padding:10px 14px;font-size:.9rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-input-bg);color:var(--color-text);outline:none;font-family:inherit}.share-select:focus{border-color:var(--color-accent)}.share-add-btn{padding:10px 20px;font-size:.85rem;font-weight:600;color:#fff;background:var(--color-accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s}.share-add-btn:hover{background:var(--color-accent-dark)}.share-add-btn:disabled{opacity:.5;cursor:not-allowed}.collaborator-list{list-style:none;padding:0;margin:0 0 16px}.collaborator-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:.9rem}.collaborator-remove{background:none;border:none;color:#c0392b;font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:4px}.collaborator-remove:hover{background:#c0392b1a}.share-empty{color:var(--color-text-muted);font-size:.9rem;text-align:center;margin:16px 0}.share-close-btn{width:100%;padding:10px;font-size:.9rem;color:var(--color-text-muted);background:none;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-family:inherit;transition:background .2s}.share-close-btn:hover{background:var(--color-border)}.dashboard-empty{text-align:center;color:#fff9;font-size:1rem;margin-top:60px}@media(max-width:640px){.dashboard{padding:50px 16px 30px}.dashboard-header{flex-direction:column;gap:12px;align-items:stretch}.dashboard-header h1{font-size:1.4rem}.dashboard-create-btn{width:100%;text-align:center}.dashboard-grid{grid-template-columns:1fr}.dashboard-card .card-action{opacity:1}.dashboard-create{padding:16px}.share-dialog{margin:16px;padding:20px;max-height:85vh;overflow-y:auto}.share-add-row{flex-direction:column}.share-add-btn{width:100%}.dashboard-section-title{font-size:1rem;margin:24px 0 12px}}@media(max-width:374px){.dashboard{padding:46px 12px 24px}}.slideshow-container{position:relative;width:100%;max-width:1200px;height:100vh;margin:0 auto;display:flex;align-items:center;justify-content:center;overflow:hidden}.slideshow-content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.slide-wrapper{position:relative;width:100%;height:100%;perspective:1000px}.slide-wrapper.right .slide{animation:slideInRight .6s cubic-bezier(.68,-.55,.265,1.55)}.slide-wrapper.left .slide{animation:slideInLeft .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes slideInRight{0%{opacity:0;transform:translate(100px) rotateY(20deg)}to{opacity:1;transform:translate(0) rotateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px) rotateY(-20deg)}to{opacity:1;transform:translate(0) rotateY(0)}}.slide{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr;gap:40px;height:100%;align-items:center}.slide-image{grid-column:1;grid-row:1 / 3;display:flex;align-items:center;justify-content:center;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px var(--color-shadow);background:var(--color-surface);padding:20px}.slide-image img{width:100%;height:100%;object-fit:cover;border-radius:16px}.slide-placeholder{grid-column:1;grid-row:1 / 3;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-surface);border-radius:20px;border:3px dashed var(--color-border-accent)}.placeholder-text{color:var(--color-text-muted);font-size:1.2rem}.slide-info{grid-column:2;grid-row:1 / 3;display:flex;flex-direction:column;justify-content:center;padding:40px;background:var(--color-surface);border-radius:20px;box-shadow:0 10px 40px var(--color-shadow);border:1px solid var(--color-border-accent)}.slide-date{display:block;font-size:.9rem;color:var(--color-accent);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:15px}.slide-title{font-size:2.5rem;color:var(--color-text);margin:0 0 20px;font-weight:700;line-height:1.2}.slide-text{font-size:1.1rem;color:var(--color-text-muted);line-height:1.8;margin:0}.nav-button{position:absolute;top:50%;transform:translateY(-50%);background:var(--color-accent);border:none;color:#fff;font-size:3rem;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:.8}.nav-button:hover{opacity:1;transform:translateY(-50%) scale(1.1)}.nav-button:active{transform:translateY(-50%) scale(.95)}.nav-button.prev{left:20px}.nav-button.next{right:20px}.slide-indicators{position:absolute;bottom:30px;left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:10}.indicator{width:12px;height:12px;border-radius:50%;background:var(--color-border-accent);border:2px solid var(--color-accent);cursor:pointer;transition:all .3s ease;padding:0;margin:0}.indicator:hover{opacity:.7}.indicator.active{background:var(--color-accent);width:30px;border-radius:6px}.slide-counter{position:absolute;top:30px;right:30px;display:flex;gap:8px;font-size:1.2rem;font-weight:600;color:var(--color-accent);background:var(--color-btn-bg);padding:12px 20px;border-radius:30px;box-shadow:0 4px 20px var(--color-shadow);z-index:10}.divider{margin:0 4px}.slide-edit-actions{display:flex;gap:8px;margin-top:20px;flex-wrap:wrap}.toolbar-btn{padding:8px 20px;font-size:.85rem;color:var(--color-accent);background:var(--color-btn-bg);border:1px solid var(--color-border-accent);border-radius:20px;cursor:pointer;transition:all .2s}.toolbar-btn:hover{background:var(--color-accent);color:#fff}.toolbar-btn.delete{color:#c0392b;border-color:#c0392b4d}.toolbar-btn.delete:hover{background:#c0392b;color:#fff}.slide-image,.slide-placeholder{position:relative}.photo-actions{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px}.photo-btn{padding:8px 16px;font-size:.8rem;color:#fff;background:var(--color-accent);opacity:.9;border:none;border-radius:16px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap}.photo-btn:hover{opacity:1}.photo-btn.remove{background:#c0392bd9}.photo-btn.remove:hover{background:#c0392b}.edit-input{width:100%;padding:10px 14px;font-size:.95rem;border:1px solid var(--color-border);border-radius:8px;outline:none;transition:border-color .2s;font-family:inherit;box-sizing:border-box;margin-bottom:12px;background:var(--color-input-bg);color:var(--color-text)}.edit-input:focus{border-color:var(--color-accent)}.edit-input.edit-title{font-family:Righteous,Arial,sans-serif;font-size:1.5rem;font-weight:700}.edit-input.edit-date{font-size:.9rem;color:var(--color-accent);max-width:200px}textarea.edit-input{resize:vertical;min-height:80px;line-height:1.8}.edit-actions{display:flex;gap:10px;margin-top:4px}.edit-btn{flex:1;padding:10px;font-size:.9rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.edit-btn.save{color:#fff;background:var(--color-accent)}.edit-btn.save:hover{background:var(--color-accent-dark)}.edit-btn.save:disabled{opacity:.6;cursor:not-allowed}.edit-btn.cancel{color:var(--color-text-muted);background:none;border:1px solid var(--color-border)}.edit-btn.cancel:hover{border-color:var(--color-text-muted)}.back-button{position:absolute;top:30px;left:30px;z-index:10;padding:10px 20px;font-size:.9rem;font-weight:500;color:var(--color-accent);background:var(--color-btn-bg);border:1px solid var(--color-border-accent);border-radius:20px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.back-button:hover{background:var(--color-accent);color:#fff}.slideshow-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;color:var(--color-text-muted);font-size:1.1rem}.nav-button:disabled{opacity:.3;cursor:not-allowed}.nav-button:disabled:hover{transform:translateY(-50%);opacity:.3}@media(max-width:1024px){.slide{grid-template-columns:1fr;grid-template-rows:auto auto;gap:30px}.slide-image,.slide-placeholder{grid-column:1;grid-row:1;max-height:400px}.slide-info{grid-column:1;grid-row:2;padding:30px}.slide-title{font-size:2rem}.slide-text{font-size:1rem}.nav-button{width:50px;height:50px;font-size:2rem}.nav-button.prev{left:10px}.nav-button.next{right:10px}}@media(max-width:640px){.slideshow-container{height:auto;min-height:100vh;overflow:visible}.slideshow-content{padding:56px 14px 14px}.slide{gap:20px;padding:8px 0 84px}.slide-image{max-height:280px;padding:10px;border-radius:14px}.slide-image img{border-radius:10px}.slide-placeholder{max-height:200px;border-radius:14px}.placeholder-text{font-size:.95rem;margin-bottom:40px}.slide-placeholder .photo-actions{bottom:auto;top:50%;margin-top:16px}.slide-info{padding:20px;border-radius:14px}.slide-date{font-size:.8rem;margin-bottom:12px}.slide-title{font-size:1.3rem;margin-bottom:14px}.slide-text{font-size:.9rem;line-height:1.7}.nav-button{display:none}.back-button{top:10px;left:10px;padding:7px 16px;font-size:.8rem}.slide-counter{top:10px;left:50%;right:auto;transform:translate(-50%);font-size:.8rem;padding:7px 14px}.slide-indicators{bottom:30px;gap:6px}.indicator{width:8px;height:8px}.indicator.active{width:20px}.slide-edit-actions{gap:8px;margin-top:18px}.toolbar-btn{padding:8px 16px;font-size:.8rem}.photo-actions{bottom:12px;gap:8px}.photo-btn{padding:7px 14px;font-size:.75rem}.edit-input{margin-bottom:14px}.edit-input.edit-title{font-size:1.2rem}.edit-actions{flex-direction:column;gap:10px;margin-top:8px}}@media(max-width:374px){.slideshow-content{padding:50px 10px 10px}.slide-counter{font-size:.7rem;padding:5px 10px}.back-button{padding:6px 12px;font-size:.75rem}.slide-title{font-size:1.1rem}.slide-text{font-size:.85rem}.slide-image{max-height:220px}.toolbar-btn{padding:6px 12px;font-size:.75rem}}.reorder-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.reorder-panel{background:var(--color-surface);border-radius:16px;padding:24px;width:100%;max-width:400px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.reorder-panel h3{font-family:Righteous,Arial,sans-serif;font-size:1.1rem;color:var(--color-text);margin:0 0 16px}.reorder-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.reorder-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none;transition:all .15s}.reorder-item:active{cursor:grabbing}.reorder-item.dragging{opacity:.5;border-color:var(--color-accent)}.reorder-handle{color:var(--color-text-muted);font-size:1rem;flex-shrink:0}.reorder-title{flex:1;font-size:.9rem;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reorder-date{font-size:.75rem;color:var(--color-text-muted);flex-shrink:0}.reorder-actions{display:flex;gap:8px}.messages-section{max-width:600px;margin:0 auto;padding:60px 20px 40px}.messages-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.messages-header h2{font-family:Righteous,Arial,sans-serif;font-size:1.4rem;color:#fff;margin:0}.messages-send-toggle{padding:8px 20px;font-size:.85rem;font-weight:500;color:#7a2e3f;background:#ffffffe6;border:none;border-radius:20px;cursor:pointer;transition:all .2s}.messages-send-toggle:hover{background:#fff}.message-compose{background:var(--color-surface);border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 4px 15px var(--color-shadow);display:flex;flex-direction:column;gap:12px}.message-select{width:100%;padding:10px 14px;font-size:.95rem;border:1px solid var(--color-border);border-radius:8px;outline:none;font-family:inherit;background:var(--color-input-bg);color:var(--color-text)}.message-select:focus{border-color:var(--color-accent)}.message-textarea{width:100%;padding:10px 14px;font-size:.95rem;border:1px solid var(--color-border);border-radius:8px;outline:none;font-family:inherit;box-sizing:border-box;resize:vertical;min-height:60px;background:var(--color-input-bg);color:var(--color-text)}.message-textarea:focus{border-color:var(--color-accent)}.message-send-btn{align-self:flex-start;padding:10px 24px;font-size:.9rem;font-weight:600;color:#fff;background:var(--color-accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s}.message-send-btn:hover{background:var(--color-accent-dark)}.message-send-btn:disabled{opacity:.5;cursor:not-allowed}.messages-list{display:flex;flex-direction:column;gap:12px}.message-card{background:var(--color-surface);border-radius:12px;padding:20px;box-shadow:0 2px 10px var(--color-shadow);border:1px solid var(--color-border)}.message-meta{display:flex;justify-content:space-between;margin-bottom:10px}.message-from-row{display:flex;align-items:center;gap:8px}.message-from{font-size:.85rem;font-weight:600;color:var(--color-accent)}.message-date{font-size:.8rem;color:var(--color-text-muted)}.message-text{font-family:Righteous,Arial,sans-serif;font-size:1rem;line-height:1.7;color:var(--color-text);margin:0;white-space:pre-wrap}.messages-empty{text-align:center;color:#fff9;font-size:.95rem;margin-top:40px}@media(max-width:640px){.messages-section{padding:50px 16px 30px}.messages-header{flex-direction:column;gap:12px;align-items:stretch;margin-bottom:16px}.messages-header h2{font-size:1.2rem}.messages-send-toggle{text-align:center}.message-compose{padding:16px}.message-send-btn{width:100%;text-align:center}.message-card{padding:14px}.message-meta{flex-direction:column;gap:2px;margin-bottom:8px}.message-text{font-size:.9rem}}@media(max-width:414px){.messages-section{padding:46px 12px 24px}}.mainpage{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.mainpage-welcome{margin-bottom:24px}.mainpage-lastseen{font-size:.85rem;color:#ffffff80;margin-top:8px}.mainpage-anniversary{display:flex;flex-direction:column;align-items:center;gap:2px;padding:20px 32px;margin-bottom:40px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:16px;cursor:pointer;transition:all .2s}.mainpage-anniversary:hover{background:#ffffff1f}.anniversary-days{font-family:Righteous,Arial,sans-serif;font-size:2.8rem;color:#fff;line-height:1}.anniversary-label{font-size:.7rem;color:#ffffff73;text-transform:uppercase;letter-spacing:1.5px}.anniversary-title{font-size:.9rem;color:#ffffffb3;margin-top:4px}.mainpage-anniversary-setup{padding:10px 24px;margin-bottom:40px;font-size:.85rem;color:#ffffff80;background:transparent;border:1px dashed rgba(255,255,255,.2);border-radius:20px;cursor:pointer;transition:all .2s}.mainpage-anniversary-setup:hover{color:#fffc;border-color:#fff6}.mainpage-welcome h1{font-family:Righteous,Arial,sans-serif;font-size:3em;color:#fff;margin:0;padding:0;letter-spacing:1px}.mainpage-nav{display:flex;gap:50px;align-items:center;justify-content:center;background:#8b3a4a;padding:40px 60px;border-radius:16px}.mainpage-item{position:relative;display:inline-block;height:35px;padding-top:15px;background:transparent;border:none;z-index:2;text-decoration:none;cursor:pointer;transition:.3s ease-in-out}.mainpage-linktext{font-size:1.3em;text-align:center;position:relative;z-index:2;color:#d4919f;text-decoration:none;font-family:Righteous,Arial,sans-serif;text-transform:uppercase;transition:.3s ease-in-out;transition-delay:0s}.mainpage-linktext:before,.mainpage-linktext:after{opacity:0;position:absolute;top:7px;transform:translateY(36px);left:0;width:100%;transition:.3s ease-in-out;font-size:.5em}.mainpage-linktext:before{content:"";height:2px;background:#5c1e2e;transition-delay:0s}.mainpage-linktext:after{content:attr(data-text);color:#d4919f;transition-delay:0s}.mainpage-item:hover .mainpage-linktext{transform:scale(1.3);color:#fff}.mainpage-item:hover .mainpage-linktext:before{transition-delay:0s}.mainpage-item:hover .mainpage-linktext:after{transition-delay:.15s}.mainpage-item:hover .mainpage-linktext:before,.mainpage-item:hover .mainpage-linktext:after{transform:translateY(16px);opacity:1}[data-theme=dark] .mainpage-nav{background:#3d1a25}[data-theme=dark] .mainpage-linktext{color:#c4788a}[data-theme=dark] .mainpage-linktext:before{background:#5c2535}[data-theme=dark] .mainpage-linktext:after{color:#c4788a}[data-theme=dark] .mainpage-item:hover .mainpage-linktext{color:#e8b4c0}@media(max-width:640px){.mainpage-welcome{margin-bottom:20px}.mainpage-anniversary{padding:16px 24px;margin-bottom:28px}.anniversary-days{font-size:2.2rem}.mainpage-anniversary-setup{margin-bottom:28px}.mainpage-welcome h1{font-size:2em}.mainpage-nav{flex-direction:column;gap:24px;padding:30px 40px;width:calc(100% - 40px);max-width:320px}.mainpage-item{min-height:44px;display:flex;align-items:center;justify-content:center}.mainpage-linktext{font-size:1.1em}}@media(max-width:374px){.mainpage-welcome h1{font-size:1.7em}.mainpage-nav{padding:24px 28px;gap:20px;width:calc(100% - 32px)}.mainpage-linktext{font-size:1em}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:var(--color-surface);border-radius:16px;padding:48px 40px;width:100%;max-width:380px;box-shadow:0 8px 40px var(--color-shadow)}.login-card h2{font-family:Righteous,Arial,sans-serif;font-size:1.6rem;color:var(--color-accent);text-align:center;margin:0 0 32px}.login-field{margin-bottom:20px}.login-field label{display:block;font-size:.85rem;font-weight:500;color:var(--color-text-muted);margin-bottom:6px}.login-field input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--color-border);border-radius:8px;outline:none;transition:border-color .2s;font-family:inherit;box-sizing:border-box;background:var(--color-input-bg);color:var(--color-text)}.login-field input:focus{border-color:var(--color-accent)}.login-btn{width:100%;padding:14px;font-size:1rem;font-weight:600;color:#fff;background:var(--color-accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s;margin-top:8px}.login-btn:hover{background:var(--color-accent-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#c0392b;font-size:.85rem;text-align:center;margin-bottom:16px}.login-hint{font-size:.9rem;color:var(--color-text-muted);text-align:center;margin:0 0 20px;line-height:1.5}.login-qr{display:flex;justify-content:center;margin-bottom:16px}.login-qr img{width:200px;height:200px;border-radius:12px;border:1px solid var(--color-border)}.login-secret{text-align:center;margin-bottom:20px}.login-secret-label{display:block;font-size:.75rem;color:var(--color-text-muted);margin-bottom:4px}.login-secret-code{font-size:.85rem;color:var(--color-accent);background:var(--color-input-bg);padding:6px 12px;border-radius:6px;letter-spacing:2px;-webkit-user-select:all;user-select:all}.login-back{width:100%;padding:10px;margin-top:8px;font-size:.9rem;color:var(--color-text-muted);background:none;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.login-back:hover{border-color:var(--color-text-muted)}@media(max-width:640px){.login-page{padding:16px}.login-card{padding:32px 24px}.login-card h2{font-size:1.3rem;margin-bottom:24px}.login-qr img{width:160px;height:160px}.login-secret-code{font-size:.75rem;word-break:break-all}}@media(max-width:414px){.login-page{align-items:flex-start;padding-top:24px}.login-card{padding:28px 20px}.login-card h2{font-size:1.2rem;margin-bottom:20px}.login-qr img{width:140px;height:140px}}.settings-page{max-width:560px;margin:0 auto;padding:60px 20px 40px}.settings-card{width:100%}.settings-header{margin-bottom:24px}.settings-header-row{display:flex;align-items:center;gap:16px}.settings-avatar{width:52px;height:52px;border-radius:50%;background:#fff3;color:#fff;font-family:Righteous,Arial,sans-serif;font-size:1.4rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-header h2{font-family:Righteous,Arial,sans-serif;font-size:1.4rem;color:#fff;margin:0}.settings-role{font-size:.8rem;color:#ffffff80;margin:2px 0 0}.settings-tabs{display:flex;gap:4px;margin-bottom:20px;background:#ffffff1a;border-radius:10px;padding:4px}.settings-tab{flex:1;padding:9px 16px;font-size:.85rem;font-weight:600;color:#fff9;background:none;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.settings-tab:hover{color:#fff}.settings-tab.active{background:#fff3;color:#fff}.settings-message{font-size:.85rem;text-align:center;margin-bottom:16px;padding:8px 12px;border-radius:8px}.settings-message.success{color:#2ecc71;background:#2ecc7126}.settings-message.error{color:#ff6b6b;background:#ff6b6b26}.settings-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.15)}.settings-section h3{font-size:.75rem;font-weight:600;color:#ffffff80;margin:0 0 14px;text-transform:uppercase;letter-spacing:1px}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.settings-toggle-label{font-size:.95rem;color:#ffffffd9}.settings-toggle{width:44px;height:24px;border-radius:12px;background:#fff3;position:relative;transition:background .2s}.settings-toggle.active{background:#fff6}.settings-toggle-knob{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0003}.settings-toggle.active .settings-toggle-knob{transform:translate(20px)}.settings-field{margin-bottom:12px}.settings-field input{width:100%;padding:11px 14px;font-size:.95rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;outline:none;transition:border-color .2s;font-family:inherit;box-sizing:border-box;background:#ffffff1a;color:#fff}.settings-field input:focus{border-color:#ffffff80}.settings-field input::placeholder{color:#fff6}.settings-btn{width:100%;padding:11px;font-size:.9rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.settings-btn.primary{color:#7a2e3f;background:#ffffffe6}.settings-btn.primary:hover{background:#fff}.settings-btn.primary:disabled{opacity:.5;cursor:not-allowed}.settings-btn-text{background:none;border:none;font-size:.85rem;cursor:pointer;padding:4px 0;transition:color .2s}.settings-btn-text.danger{color:#fff6}.settings-btn-text.danger:hover{color:#ff6b6b}.settings-totp-status{display:flex;flex-direction:column;gap:12px}.settings-totp-active{display:flex;align-items:center;gap:10px;font-size:.95rem;color:#ffffffd9}.settings-totp-dot{width:10px;height:10px;border-radius:50%;background:#ffffff4d;flex-shrink:0}.settings-totp-dot.active{background:#2ecc71;box-shadow:0 0 8px #2ecc7166}.settings-totp-setup{display:flex;flex-direction:column;gap:12px}.settings-totp-hint{font-size:.85rem;color:#fff9;margin:0;line-height:1.5}.settings-totp-qr{display:flex;justify-content:center}.settings-totp-qr img{width:180px;height:180px;border-radius:12px;border:1px solid rgba(255,255,255,.2)}.settings-totp-secret{text-align:center}.settings-totp-secret-label{display:block;font-size:.75rem;color:#ffffff80;margin-bottom:4px}.settings-totp-secret-code{font-size:.8rem;color:#fffc;background:#ffffff1a;padding:6px 12px;border-radius:6px;letter-spacing:2px;-webkit-user-select:all;user-select:all;word-break:break-all}.settings-totp-disable{display:flex;flex-direction:column;gap:8px}.settings-totp-disable-actions{display:flex;gap:8px}.settings-totp-disable-actions .settings-btn{flex:1}.settings-footer{display:flex;flex-direction:column;gap:12px}.settings-btn.logout{color:#fffc;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);font-weight:500}.settings-btn.logout:hover{background:#fff3;color:#fff}.settings-danger-toggle{background:none;border:none;color:#fff6;font-size:.8rem;cursor:pointer;padding:4px 0;text-align:center;transition:color .2s}.settings-danger-toggle:hover{color:#ff6b6b}.settings-danger-zone{border:1px solid rgba(255,107,107,.3);border-radius:8px;padding:14px;background:#ff6b6b14}.settings-danger-text{font-size:.8rem;color:#ff6b6b;margin:0 0 12px;line-height:1.4;text-align:center}.settings-danger-actions{display:flex;gap:8px}.settings-btn.danger{flex:1;background:#c0392b;color:#fff;font-weight:600}.settings-btn.danger:hover{background:#a93226}.settings-btn.cancel{flex:1;color:#fff9;background:none;border:1px solid rgba(255,255,255,.2)}.settings-btn.cancel:hover{border-color:#fff6;color:#fffc}.settings-create-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.settings-input{flex:1;min-width:120px;padding:8px 12px;font-size:.9rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;outline:none;font-family:inherit;background:#ffffff1a;color:#fff;transition:border-color .2s}.settings-input:focus{border-color:#ffffff80}.settings-input::placeholder{color:#fff6}.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#ffffffd9;cursor:pointer;white-space:nowrap}.settings-checkbox input{accent-color:rgba(255,255,255,.8)}.settings-user-list{display:flex;flex-direction:column;gap:8px}.settings-user-row{display:flex;flex-direction:column;gap:10px;padding:14px 16px;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.settings-user-info{display:flex;align-items:center;gap:8px}.settings-user-name{font-size:.95rem;font-weight:500;color:#ffffffe6}.settings-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px;background:#fff3;color:#fff;text-transform:uppercase;letter-spacing:.5px}.settings-badge.you{background:#ffffff1f;color:#ffffff80}.settings-user-actions{display:flex;gap:6px;flex-wrap:wrap}.settings-action-btn{padding:5px 12px;font-size:.75rem;font-weight:500;color:#fffc;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.settings-action-btn:hover{background:#fff3;color:#fff}.settings-action-btn.delete{color:#ff6b6b;border-color:#ff6b6b4d}.settings-action-btn.delete:hover{background:#c0392b;color:#fff}@media(max-width:640px){.settings-page{padding:50px 16px 30px}.settings-avatar{width:44px;height:44px;font-size:1.2rem}.settings-header h2{font-size:1.2rem}.settings-tabs{margin-bottom:16px}.settings-tab{padding:8px 12px;font-size:.8rem}.settings-section{margin-bottom:20px;padding-bottom:20px}.settings-section h3{font-size:.7rem;margin-bottom:12px}.settings-field input{padding:10px 12px;font-size:.9rem}.settings-btn{padding:10px;font-size:.85rem}.settings-danger-actions{flex-direction:column}.settings-totp-qr img{width:160px;height:160px}.settings-totp-disable-actions,.settings-create-form{flex-direction:column}.settings-input{width:100%;min-width:0}.settings-user-row{flex-direction:column;gap:10px;align-items:flex-start;padding:12px}.settings-user-actions{width:100%;flex-wrap:wrap}.settings-action-btn{flex:1;text-align:center;padding:6px 10px}}@media(max-width:374px){.settings-page{padding:46px 12px 24px}.settings-totp-qr img{width:140px;height:140px}.settings-totp-secret-code{font-size:.7rem}.settings-action-btn{flex:0 1 calc(50% - 3px);text-align:center;padding:8px 6px;font-size:.7rem}}.calendar-page{max-width:600px;margin:0 auto;padding:60px 20px 40px}.calendar-title{font-family:Righteous,Arial,sans-serif;font-size:1.8rem;color:#fff;margin:0 0 24px}.calendar-countdowns{display:flex;gap:12px;margin-bottom:28px;overflow-x:auto}.countdown-card{flex:1;min-width:100px;padding:16px 12px;border-radius:12px;background:#ffffff1a;text-align:center;display:flex;flex-direction:column;gap:2px;border-left:4px solid}.countdown-card.event-rose{border-color:#e84393}.countdown-card.event-blue{border-color:#0984e3}.countdown-card.event-green{border-color:#00b894}.countdown-card.event-gold{border-color:#fdcb6e}.countdown-card.event-purple{border-color:#6c5ce7}.countdown-days{font-family:Righteous,Arial,sans-serif;font-size:2rem;color:#fff;line-height:1}.countdown-label{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:1px}.countdown-title{font-size:.8rem;color:#fffc;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-nav-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.calendar-nav-btn:hover{background:#fff3}.calendar-month-label{font-family:Righteous,Arial,sans-serif;font-size:1.1rem;color:#fff}.calendar-grid{display:grid;grid-template-columns:28px repeat(7,1fr);gap:4px;margin-bottom:24px}.calendar-weekday{text-align:center;font-size:.75rem;font-weight:600;color:#ffffff80;padding:8px 0;text-transform:uppercase;letter-spacing:1px}.calendar-kw-header{letter-spacing:0}.calendar-kw{display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#ffffff59;font-weight:500}.calendar-day{aspect-ratio:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;transition:all .15s;padding:4px}.calendar-day:hover{background:#ffffff1f}.calendar-day.empty{background:transparent;border-color:transparent;cursor:default}.calendar-day.today{border-color:#fff6;background:#ffffff1f}.calendar-day.selected{background:#fff3;border-color:#ffffff80}.day-number{font-size:.85rem;color:#ffffffd9;font-weight:500}.calendar-day.today .day-number{color:#fff;font-weight:700}.day-dots{display:flex;gap:3px;flex-wrap:wrap;justify-content:center}.day-dot{width:6px;height:6px;border-radius:50%}.event-bg-rose{background:#e84393}.event-bg-blue{background:#0984e3}.event-bg-green{background:#00b894}.event-bg-gold{background:#fdcb6e}.event-bg-purple{background:#6c5ce7}.event-border-rose{border-left:3px solid #e84393}.event-border-blue{border-left:3px solid #0984e3}.event-border-green{border-left:3px solid #00b894}.event-border-gold{border-left:3px solid #fdcb6e}.event-border-purple{border-left:3px solid #6c5ce7}.calendar-day.holiday .day-number{color:#ff6b6b}.day-dot-holiday{background:#ff6b6b}.day-holiday-badge{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ff6b6b1f;border-left:3px solid #ff6b6b;border-radius:8px;margin-bottom:10px;font-size:.9rem;color:#ffffffe6;font-weight:500}.calendar-day-detail{background:#ffffff14;border-radius:12px;padding:20px;margin-bottom:16px}.day-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.day-detail-header h3{font-family:Righteous,Arial,sans-serif;font-size:1rem;color:#fff;margin:0}.calendar-add-btn{padding:6px 16px;font-size:.8rem;font-weight:600;color:#7a2e3f;background:#ffffffe6;border:none;border-radius:16px;cursor:pointer;transition:all .2s}.calendar-add-btn:hover{background:#fff}.day-detail-empty{color:#ffffff80;font-size:.9rem;text-align:center;margin:0}.day-detail-events{display:flex;flex-direction:column;gap:10px}.day-event{background:#ffffff0f;border-radius:8px;padding:12px}.day-event-info{display:flex;align-items:center;gap:8px;margin-bottom:4px}.day-event-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.day-event-title{font-size:.95rem;font-weight:600;color:#ffffffe6}.day-event-desc{font-size:.85rem;color:#fff9;margin:4px 0 8px 18px;line-height:1.4}.day-event-actions{display:flex;gap:8px;margin-left:18px}.day-event-btn{padding:4px 12px;font-size:.75rem;color:#ffffffb3;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:12px;cursor:pointer;transition:all .2s}.day-event-btn:hover{background:#ffffff26;color:#fff}.day-event-btn.delete{color:#ff6b6b;border-color:#ff6b6b33}.day-event-btn.delete:hover{background:#ff6b6b26}.calendar-add-floating{display:block;margin:0 auto;padding:10px 24px;font-size:.9rem;font-weight:600;color:#7a2e3f;background:#ffffffe6;border:none;border-radius:20px;cursor:pointer;transition:all .2s}.calendar-add-floating:hover{background:#fff}.calendar-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.calendar-dialog{background:var(--color-surface);border-radius:16px;padding:28px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:14px;box-shadow:0 20px 60px #0000004d}.calendar-dialog h3{font-family:Righteous,Arial,sans-serif;font-size:1.2rem;color:var(--color-text);margin:0}.calendar-input,.calendar-textarea{width:100%;padding:10px 14px;font-size:.95rem;border:1px solid var(--color-border);border-radius:8px;outline:none;font-family:inherit;box-sizing:border-box;background:var(--color-input-bg);color:var(--color-text);transition:border-color .2s}.calendar-textarea{resize:vertical}.calendar-input:focus,.calendar-textarea:focus{border-color:var(--color-accent)}.calendar-color-picker{display:flex;gap:10px;justify-content:center}.color-chip{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s;opacity:.6}.color-chip:hover{opacity:.9;transform:scale(1.1)}.color-chip.active{opacity:1;border-color:var(--color-text);transform:scale(1.15)}.calendar-dialog-actions{display:flex;gap:8px}.calendar-btn{flex:1;padding:10px;font-size:.9rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.calendar-btn.primary{color:#fff;background:var(--color-accent)}.calendar-btn.primary:hover{background:var(--color-accent-dark)}.calendar-btn.cancel{color:var(--color-text-muted);background:none;border:1px solid var(--color-border)}.calendar-btn.cancel:hover{border-color:var(--color-text-muted)}@media(max-width:640px){.calendar-page{padding:50px 12px 30px}.calendar-title{font-size:1.4rem}.calendar-nav-btn{display:none}.calendar-month-label{width:100%;text-align:center}.calendar-countdowns{gap:8px}.countdown-card{padding:12px 8px;min-width:80px}.countdown-days{font-size:1.5rem}.calendar-grid{grid-template-columns:22px repeat(7,1fr);gap:3px}.calendar-kw{font-size:.6rem}.day-number{font-size:.75rem}.day-dot{width:5px;height:5px}.calendar-dialog{padding:20px;margin:0 12px}.day-detail-header{flex-direction:column;gap:10px;align-items:flex-start}}@media(max-width:374px){.calendar-page{padding:46px 8px 24px}.calendar-grid{grid-template-columns:18px repeat(7,1fr);gap:2px}.day-number{font-size:.7rem}.day-dot{width:4px;height:4px}.calendar-kw{font-size:.55rem}.countdown-card{min-width:70px;padding:10px 6px}.countdown-days{font-size:1.3rem}.countdown-title{font-size:.7rem}}.theme-bordeaux{--color-accent: #7a2e3f;--color-accent-dark: #5c1e2e;--color-accent-light: #8b3a4a}.theme-ocean{--color-accent: #1e6091;--color-accent-dark: #154a6e;--color-accent-light: #2980b9}.theme-forest{--color-accent: #27694a;--color-accent-dark: #1b4d35;--color-accent-light: #2ecc71}.theme-sunset{--color-accent: #c0582a;--color-accent-dark: #944420;--color-accent-light: #e67e22}.theme-lavender{--color-accent: #6c3483;--color-accent-dark: #512668;--color-accent-light: #8e44ad}[data-theme=dark] .theme-ocean{--color-accent: #5dade2;--color-accent-dark: #3498db;--color-accent-light: #85c1e9}[data-theme=dark] .theme-forest{--color-accent: #58d68d;--color-accent-dark: #2ecc71;--color-accent-light: #82e0aa}[data-theme=dark] .theme-sunset{--color-accent: #eb984e;--color-accent-dark: #e67e22;--color-accent-light: #f0b27a}[data-theme=dark] .theme-lavender{--color-accent: #bb8fce;--color-accent-dark: #8e44ad;--color-accent-light: #d2b4de}[data-theme=dark] .theme-bordeaux{--color-accent: #c4788a;--color-accent-dark: #a85c6e;--color-accent-light: #d4919f}.app{position:relative;z-index:1;min-height:100vh;background:#7a2e3f}[data-theme=dark] .app{background:#2a1018}.top-bar{position:fixed;top:20px;right:20px;z-index:100;display:flex;gap:8px}.top-btn{padding:8px 20px;font-size:.85rem;color:#fffc;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:20px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.top-btn:hover{background:#fff3;color:#fff}.top-btn.icon-btn{padding:8px 10px;display:flex;align-items:center;justify-content:center}.top-btn.icon-btn.active{background:#ffffff40;color:#fff;box-shadow:0 4px 15px #0003}.page-transition{animation:pageFadeIn .3s ease-out}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.top-bar{top:10px;right:10px;gap:6px}.top-btn{padding:6px 14px;font-size:.8rem}.top-btn.icon-btn{padding:6px 8px}}
