*,:before,:after{box-sizing:border-box;margin:0;padding:0}body.dihen-page--anniversary-index .dihen-page-frame__scroll{--brand:#4a3fa8;--brand-mid:#6357c4;--brand-light:#eae8ff;--brand-xlight:#f5f4ff;--cream:#fafaf7;--surface:#fff;--ink:#1a1a2e;--ink-70:#4a4a68;--ink-40:#9a9ab8;--ink-15:#e8e8f2;--border:#4a3fa81a;--border-med:#4a3fa82e;--rose:#e8526a;--rose-light:#fdedf0;--peach:#f07850;--peach-light:#fef0ea;--amber:#d4920a;--amber-light:#fef6e4;--teal:#0d9b82;--teal-light:#e3f6f2;--violet:#7c5cbf;--violet-light:#f0eafb;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-pill:100px;--font-display:"Lora", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif;--nav-h:62px;--ease:cubic-bezier(.16, 1, .3, 1)}@keyframes pulse-ring{0%{opacity:.6;transform:scale(1)}70%{opacity:0;transform:scale(1.5)}to{opacity:0;transform:scale(1.5)}}@keyframes countdown-tick{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.page{max-width:880px;margin:0 auto;padding:30px 24px 80px}.page-header{animation:fadeUp .5s var(--ease) both;justify-content:space-between;align-items:flex-start;margin-bottom:36px;display:flex}.page-title{font-family:var(--font-display);letter-spacing:-.5px;color:var(--ink);font-size:30px;font-weight:600;line-height:1.2}.page-title em{color:var(--brand);font-style:italic}.page-subtitle{color:var(--ink-70);margin-top:6px;font-size:15px}.stat-chips{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.stat-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--ink-70);align-items:center;gap:5px;padding:5px 12px;font-size:13px;display:flex}.stat-chip b{color:var(--ink);font-weight:500}.stat-chip-dot{background:var(--rose);border-radius:50%;flex-shrink:0;width:7px;height:7px}.stat-chip-dot.green{background:var(--teal)}.stat-chip-dot.amber{background:var(--amber)}.upcoming-banner{border-radius:var(--radius-xl);cursor:pointer;animation:fadeUp .5s 80ms var(--ease) both;transition:transform .2s var(--ease);background:linear-gradient(135deg,#2d2470 0%,#4a3fa8 50%,#7c5cbf 100%);align-items:center;gap:20px;margin-bottom:32px;padding:24px 28px;display:flex;position:relative;overflow:hidden}.upcoming-banner:hover{transform:translateY(-2px)}.upcoming-banner:before{content:"";pointer-events:none;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='28' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3C/svg%3E");position:absolute;inset:0}.banner-icon-wrap{flex-shrink:0;position:relative}.banner-icon{background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex}.banner-ring{border:2px solid #fff6;border-radius:50%;animation:2s ease-out infinite pulse-ring;position:absolute;inset:-4px}.banner-body{flex:1;min-width:0}.banner-tag{color:#ffffffe6;letter-spacing:.5px;text-transform:uppercase;border-radius:var(--radius-pill);background:#fff3;margin-bottom:6px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-block}.banner-title{font-family:var(--font-display);color:#fff;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:20px;font-weight:600;line-height:1.25;overflow:hidden}.banner-sub{color:#ffffffb8;font-size:14px}.banner-countdown{text-align:center;flex-shrink:0}.countdown-num{font-family:var(--font-display);color:#fff;font-size:44px;font-weight:600;line-height:1;animation:2s ease-in-out infinite countdown-tick}.countdown-label{color:#fff9;margin-top:2px;font-size:12px}.banner-actions{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.banner-btn{color:#fff;border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font-body);background:#ffffff26;border:1px solid #ffffff40;align-items:center;gap:6px;padding:8px 14px;transition:background .15s;display:flex}.banner-btn:hover{background:#ffffff40}.banner-btn.primary{color:var(--brand);background:#fff;border-color:#0000}.banner-btn.primary:hover{background:#ffffffe6}.banner-btn svg{width:14px;height:14px}.section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.section-title{font-family:var(--font-display);color:var(--ink);align-items:center;gap:8px;font-size:17px;font-weight:500;display:flex}.section-title-dot{background:var(--rose);border-radius:50%;width:8px;height:8px}.section-title-dot.teal{background:var(--teal)}.section-more{color:var(--brand);cursor:pointer;align-items:center;gap:4px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.section-more:hover{text-decoration:underline}.filter-bar{scrollbar-width:none;animation:fadeUp .5s .12s var(--ease) both;gap:8px;margin-bottom:24px;padding-bottom:2px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-pill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--ink-70);cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;padding:7px 16px;font-size:13px;transition:all .15s;display:flex}.filter-pill:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xlight)}.filter-pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}.filter-pill .pill-count{color:inherit;background:#ffffff40;border-radius:99px;padding:1px 6px;font-size:11px;font-weight:500}.filter-pill:not(.active) .pill-count{background:var(--ink-15);color:var(--ink-70)}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.ann-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:default;transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s;animation:fadeUp .5s var(--ease) both;position:relative;overflow:hidden}.ann-card:hover{border-color:var(--brand-mid);transform:translateY(-4px);box-shadow:0 12px 32px #4a3fa81f}.ann-card-link{color:inherit;cursor:pointer;text-decoration:none;display:block}.ann-card-link:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.ann-card-stripe{height:5px}.stripe-rose{background:var(--rose)}.stripe-peach{background:var(--peach)}.stripe-amber{background:var(--amber)}.stripe-teal{background:var(--teal)}.stripe-violet{background:var(--violet)}.stripe-brand{background:var(--brand)}.ann-card-body{padding:18px 18px 14px}.ann-card-top{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.ann-emoji-wrap{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.ann-emoji-wrap.rose{background:var(--rose-light)}.ann-emoji-wrap.peach{background:var(--peach-light)}.ann-emoji-wrap.amber{background:var(--amber-light)}.ann-emoji-wrap.teal{background:var(--teal-light)}.ann-emoji-wrap.violet{background:var(--violet-light)}.ann-emoji-wrap.brand{background:var(--brand-light)}.ann-card-menu{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--ink-40);cursor:pointer;z-index:1;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.ann-card-menu:hover{background:var(--ink-15);color:var(--ink)}.ann-card-menu svg{width:16px;height:16px}.ann-name{font-family:var(--font-display);color:var(--ink);flex:1;min-width:0;font-size:16px;font-weight:600;line-height:1.3;overflow:hidden}.ann-type-tag{letter-spacing:.3px;border-radius:var(--radius-pill);align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.tag-rose{background:var(--rose-light);color:#b83451}.tag-peach{background:var(--peach-light);color:#b85230}.tag-amber{background:var(--amber-light);color:#9a6a08}.tag-teal{background:var(--teal-light);color:#0a7561}.tag-violet{background:var(--violet-light);color:#5c3e99}.tag-brand{background:var(--brand-light);color:var(--brand)}.ann-date-row{border-top:1px solid var(--ink-15);justify-content:space-between;align-items:center;padding:10px 0 0;display:flex}.ann-date-label{color:var(--ink-40);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.ann-date-value{color:var(--ink);margin-top:1px;font-size:15px;font-weight:500}.ann-date-year{color:var(--ink-40);font-size:12px}.ann-countdown{text-align:right}.ann-countdown-num{font-family:var(--font-display);font-size:26px;font-weight:600;line-height:1}.ann-countdown-label{color:var(--ink-40);font-size:11px}.ann-countdown-num.urgent{color:var(--rose)}.ann-countdown-num.soon{color:var(--amber)}.ann-countdown-num.ok{color:var(--teal)}.ann-countdown-num.far{color:var(--brand)}.ann-countdown-num.today{color:var(--rose);font-style:italic}.ann-year-badge{color:var(--ink-70);background:var(--ink-15);border-radius:var(--radius-pill);align-items:center;gap:4px;padding:3px 8px;font-size:12px;display:inline-flex}.ann-year-badge b{color:var(--ink);font-weight:500}.ann-card-footer{border-top:1px solid var(--border);background:var(--cream);align-items:center;gap:6px;padding:12px 18px;display:flex}.ann-footer-btn{color:var(--ink-70);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-body);align-items:center;gap:5px;padding:6px 10px;transition:all .15s;display:flex}.ann-footer-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xlight)}.ann-footer-btn svg{width:12px;height:12px}.ann-footer-spacer{flex:1}.ann-footer-share{width:30px;height:30px;color:var(--ink-40);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.ann-footer-share:hover{background:var(--ink-15);color:var(--ink)}.ann-footer-share svg{width:14px;height:14px}.ann-today-badge{background:var(--rose);color:#fff;letter-spacing:.5px;text-transform:uppercase;border-radius:var(--radius-pill);padding:3px 8px;font-size:10px;font-weight:600;position:absolute;top:16px;right:16px}.empty-state{text-align:center;animation:fadeUp .5s var(--ease) both;padding:60px 20px}.empty-icon{margin-bottom:16px;font-size:52px;display:block}.empty-title{font-family:var(--font-display);color:var(--ink);margin-bottom:8px;font-size:20px;font-weight:500}.empty-sub{color:var(--ink-70);max-width:340px;margin:0 auto 20px;font-size:15px}.empty-btn{background:var(--brand);color:#fff;border-radius:var(--radius-pill);cursor:pointer;font-size:15px;font-weight:500;font-family:var(--font-body);border:none;align-items:center;gap:8px;padding:12px 24px;transition:background .15s;display:inline-flex}.empty-btn:hover{background:var(--brand-mid)}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;background:#1a1a2e80;justify-content:center;align-items:flex-end;transition:opacity .25s;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:560px;transition:transform .35s var(--ease);max-height:90vh;padding:8px 0 0;overflow-y:auto;transform:translateY(40px)}.modal-backdrop.open .modal{transform:translateY(0)}.modal-handle{background:var(--ink-15);border-radius:2px;width:40px;height:4px;margin:0 auto 20px}.modal-header{border-bottom:1px solid var(--border);padding:0 24px 20px}.modal-title{font-family:var(--font-display);color:var(--ink);font-size:20px;font-weight:600}.modal-sub{color:var(--ink-70);margin-top:4px;font-size:14px}.modal-body{flex-direction:column;gap:18px;padding:24px;display:flex}.form-label{color:var(--ink-70);margin-bottom:7px;font-size:13px;font-weight:500;display:block}.form-label span{color:var(--rose)}.form-input{border:1px solid var(--border-med);border-radius:var(--radius-md);width:100%;font-family:var(--font-body);color:var(--ink);background:var(--cream);outline:none;padding:11px 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--brand);background:var(--surface);box-shadow:0 0 0 3px #4a3fa81f}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.emoji-picker-row{flex-wrap:wrap;gap:8px;display:flex}.emoji-opt{border-radius:var(--radius-md);border:2px solid var(--border);background:var(--cream);cursor:pointer;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;transition:border-color .15s,background .15s,transform .1s;display:flex}.emoji-opt:hover{border-color:var(--brand);background:var(--brand-xlight)}.emoji-opt.active{border-color:var(--brand);background:var(--brand-xlight);transform:scale(1.1)}.type-picker-row{flex-wrap:wrap;gap:8px;display:flex}.type-opt{border:1.5px solid var(--border-med);border-radius:var(--radius-pill);cursor:pointer;color:var(--ink-70);font-size:13px;font-weight:500;font-family:var(--font-body);align-items:center;gap:6px;padding:7px 14px;transition:all .15s;display:flex}.type-opt:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xlight)}.type-opt.active{background:var(--brand);color:#fff;border-color:var(--brand)}.modal-footer{gap:10px;padding:16px 24px 32px;display:flex}.btn-cancel{border-radius:var(--radius-pill);border:1px solid var(--border-med);background:var(--surface);font-family:var(--font-body);color:var(--ink-70);cursor:pointer;flex:1;padding:13px;font-size:15px;transition:background .15s}.btn-cancel:hover{background:var(--ink-15)}.btn-save{border-radius:var(--radius-pill);background:var(--brand);color:#fff;font-family:var(--font-body);cursor:pointer;border:none;flex:2;padding:13px;font-size:15px;font-weight:500;transition:background .15s}.btn-save:hover{background:var(--brand-mid)}.section-divider{color:var(--ink-40);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:12px;margin:8px 0 16px;font-size:12px;display:flex}.section-divider:before,.section-divider:after{content:"";background:var(--border);flex:1;height:1px}.toast{background:var(--ink);color:#fff;border-radius:var(--radius-pill);z-index:300;opacity:0;white-space:nowrap;pointer-events:none;padding:10px 20px;font-size:14px;font-weight:500;transition:opacity .2s,transform .2s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(8px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=768px){.page{padding:16px 16px 60px}.page-title{font-size:26px}.page-subtitle{font-size:14px}.upcoming-banner{flex-wrap:wrap;gap:16px;padding:20px}.banner-icon{width:48px;height:48px;font-size:22px}.banner-title{font-size:18px}.countdown-num{font-size:36px}.banner-actions{flex-direction:row;width:100%}.banner-btn{flex:1;justify-content:center}.cards-grid{grid-template-columns:1fr;gap:16px}.ann-card-body{padding:12px}.ann-card-footer{padding:14px 14px 12px}.ann-emoji-wrap{width:40px;height:40px;font-size:20px}.ann-date-row{margin-bottom:10px;padding:8px 0}.ann-countdown-num{font-size:24px}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px}}a.ann-footer-btn{text-decoration:none}.ann-plan-btn--exists{background:var(--brand-xlight);border-color:var(--brand-mid);color:var(--brand)}.ann-plan-btn--exists:hover{background:var(--brand);color:#fff}.guest-empty-state{text-align:center;animation:fadeUp .5s var(--ease) both;padding:80px 20px 60px}.guest-empty-icon{margin-bottom:20px;font-size:56px;display:block}.guest-empty-title{font-family:var(--font-display);color:var(--ink);margin-bottom:10px;font-size:22px;font-weight:600;line-height:1.3}.guest-empty-desc{color:var(--ink-70);max-width:420px;margin:0 auto 28px;font-size:15px;line-height:1.6}.guest-empty-btn{background:var(--brand);color:#fff;border-radius:var(--radius-pill);cursor:pointer;font-size:15px;font-weight:500;font-family:var(--font-body);border:none;align-items:center;gap:8px;padding:14px 28px;text-decoration:none;transition:background .15s;display:inline-flex}.guest-empty-btn:hover{background:var(--brand-mid);color:#fff}
