:root{--paper-bg:#fdfaf6;--paper-dark:#f0e9dd;--wood-bg:#5c4033;--surface-card:#ffffff80;--surface-raised:#fff9;--ink-color:#2c2c2c;--ink-light:#707070;--ink-muted:#2c2c2c66;--accent:#1a237e;--accent-light:#283593;--accent-on:#fff9c4;--accent-border:#1a237e4d;--accent-subtle:#1a237e0f;--accent-glow:#1a237e1f;--highlight:#ffd60080;--grid-line:#64503c26;--weekday-color:#64503c99;--range-dot:#f59e0b;--range-dot-glow:#f59e0b80;--range-strip:#ffd60038;--today-color:#d32f2f;--notes-bg:#fff9c4;--notes-line:#accce28c;--notes-border:#ff7b7b;--notes-title-color:#1a237e;--event-border:#1a237e;--event-bg:#ffffff80;--event-bg-hover:#ffffffd9;--event-delete:#d32f2f80;--input-bg:#ffffffb3;--input-bg-focus:#fffffff2;--input-border:#1a237e40;--input-color:#1a237e;--input-caret:#1a237e;--input-placeholder:#1a237e59;--btn-primary-bg:#1a237e;--btn-primary-color:#fff9c4;--btn-cancel-color:#1a237e;--btn-cancel-border:#1a237e66;--sticky-bg:#fff59d;--sticky-ink:#1a237e;--sticky-caret:#1a237e;--sticky-line:#accce280;--scrollbar-thumb:#1a237e33;--neu-shadow-out:4px 4px 10px #a68c6e73, -4px -4px 10px #fffc;--neu-shadow-in:inset 3px 3px 7px #a68c6e66, inset -3px -3px 7px #ffffffbf;--neu-shadow-hover:6px 6px 14px #a68c6e8c, -6px -6px 14px #ffffffe6}[data-theme=dark]{--paper-bg:#1e1414;--paper-dark:#2e1a1a;--wood-bg:#110b0b;--surface-card:#2e1a1a99;--surface-raised:#3c141480;--ink-color:#fce4e4;--ink-light:#9e5050;--ink-muted:#fce4e459;--accent:#e53935;--accent-light:#ef5350;--accent-on:#fff0f0;--accent-border:#e5393559;--accent-subtle:#e5393512;--accent-glow:#e5393526;--highlight:#ef444440;--grid-line:#ff78780d;--weekday-color:#fcb4b480;--range-dot:#ef5350;--range-dot-glow:#ef535073;--range-strip:#ef44442e;--today-color:#ff7043;--notes-bg:#2a1515;--notes-line:#ff78781f;--notes-border:#7f1d1d;--notes-title-color:#f48fb1;--event-border:#ef5350;--event-bg:#3c141480;--event-bg-hover:#501e1ecc;--event-delete:#ef444480;--input-bg:#2e141499;--input-bg-focus:#3c1414e6;--input-border:#ef444440;--input-color:#fca5a5;--input-caret:#f87171;--input-placeholder:#fca5a559;--btn-primary-bg:#c62828;--btn-primary-color:#fff0f0;--btn-cancel-color:#fca5a5;--btn-cancel-border:#ef444466;--sticky-bg:#2d1515;--sticky-ink:#fca5a5;--sticky-caret:#f87171;--sticky-line:#ff787826;--scrollbar-thumb:#ef444440;--neu-shadow-out:6px 6px 12px #0a0606, -6px -6px 12px #2e1e1e;--neu-shadow-in:inset 4px 4px 8px #0a0606, inset -4px -4px 8px #2e1e1e;--neu-shadow-hover:8px 8px 16px #0a0606, -8px -8px 16px #321e1e}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--wood-bg);color:var(--ink-color);background-image:linear-gradient(90deg,#0000001a 0%,#0000 10% 90%,#0000001a 100%),repeating-linear-gradient(#00000008 0% 2px,#0000 2px 8px);justify-content:center;align-items:center;min-height:100vh;padding:2rem;font-family:Georgia,Times New Roman,serif;transition:background-color .5s,color .5s;display:flex;overflow-x:hidden}#app{filter:drop-shadow(0 30px 40px #00000080);width:100%;max-width:1100px;position:relative}.calendar-wrapper{perspective:1500px;width:100%}.calendar-container{background:#fdfcf7;border-radius:10px;flex-direction:row;min-height:650px;display:flex;position:relative;box-shadow:0 10px 25px #00000040,inset 0 2px 4px #00000014}[data-theme=dark] .calendar-container{background:#1e1414;box-shadow:0 5px #3a1a1a,0 6px #2a1010,0 8px 10px #0009}.spirals{z-index:20;pointer-events:none;flex-direction:column;justify-content:space-evenly;align-items:center;width:30px;height:80%;display:flex;position:absolute;top:10%;right:0;transform:translate(50%)}.spiral{background:linear-gradient(#d6d6d6 0%,#fff 30%,#a3a3a3 60%,#4a4a4a 100%);border-radius:6px;width:50px;height:14px;position:relative;box-shadow:0 2px 4px #0000004d,inset 0 1px 2px #ffffff4d}.spiral:before,.spiral:after{content:"";background:#111;border-radius:50%;width:12px;height:12px;position:absolute;top:1px;box-shadow:inset 2px 2px 4px #000c}.spiral:before{left:-6px}.spiral:after{right:-6px}.calendar-top{background-color:var(--paper-bg);z-index:2;border-radius:4px 0 0 4px;flex-direction:column;justify-content:center;width:40%;padding:30px 52px 30px 30px;display:flex;position:relative;box-shadow:inset -15px 0 30px -10px #00000026}.image-inset{border-radius:12px;width:100%;height:350px;padding:10px;position:relative;overflow:hidden;transform:rotate(-1deg);box-shadow:0 6px 15px #00000040}.hero-image{z-index:1;filter:none;opacity:1;box-shadow:none;background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:6px;outline:none;position:absolute}.image-overlay{display:none}.image-loader-sheen{z-index:3;animation:1.5s infinite sheen;position:absolute;inset:0}@keyframes sheen{0%{background-position:-200% 0}to{background-position:200% 0}}.image-blur,.image-clear{filter:none;opacity:1}.month-hero-title{text-align:center;color:#fff;z-index:3;text-shadow:0 2px 8px #0009,0 0 20px #0006;opacity:.95;pointer-events:none;width:100%;font-family:Brush Script MT,Comic Sans MS,cursive;font-size:2.8rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.calendar-bottom{background:var(--paper-bg);border-radius:0 4px 4px 0;flex-direction:column;width:60%;padding:3rem 4rem;display:flex;box-shadow:inset 15px 0 30px -10px #00000026}.calendar-header{border-bottom:2px solid var(--grid-line);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1.2rem;display:flex}.current-month-year{color:var(--ink-color);text-transform:uppercase;letter-spacing:3px;margin:0;font-family:Georgia,Times New Roman,serif;font-size:1.9rem;font-weight:700}.nav-btn{background:var(--paper-dark);border:1.5px solid var(--grid-line);cursor:pointer;width:36px;min-width:36px;height:36px;color:var(--ink-color);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex;box-shadow:1px 2px 4px #0000001f}.nav-btn:hover{background:var(--wood-bg);color:var(--paper-bg);border-color:var(--wood-bg);box-shadow:0 3px 8px #00000040}.nav-btn:active{box-shadow:none;transform:scale(.9)}.calendar-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:1.5rem;display:flex}.today-btn{background:var(--paper-dark);color:var(--ink-color);border:1.5px solid var(--grid-line);cursor:pointer;letter-spacing:.5px;border-radius:20px;padding:6px 16px;font-family:Georgia,serif;font-size:.9rem;font-weight:700;transition:all .15s;box-shadow:1px 2px 4px #0000001f}.today-btn:hover{background:var(--wood-bg);color:var(--paper-bg);border-color:var(--wood-bg)}.today-btn:active{box-shadow:none;transform:translateY(1px)}.date-input-wrapper{border:1.5px solid var(--grid-line);background:var(--paper-bg);border-radius:20px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden;box-shadow:inset 1px 1px 3px #00000014}.date-input-wrapper.goto-error{border-color:#d32f2f;animation:.3s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.goto-label{color:var(--ink-light);white-space:nowrap;padding:0 8px 0 14px;font-family:Georgia,serif;font-size:.85rem}.date-input{width:85px;color:var(--ink-color);background:0 0;border:none;outline:none;padding:6px 4px;font-family:Georgia,serif;font-size:.9rem}.date-input::placeholder{color:var(--ink-light);opacity:.7}.goto-btn{background:var(--wood-bg);color:var(--paper-bg);cursor:pointer;letter-spacing:.5px;border:none;border-radius:0 20px 20px 0;align-items:center;gap:4px;padding:6px 13px;font-family:Georgia,serif;font-size:.8rem;font-weight:700;line-height:1;transition:all .15s;display:flex}.goto-btn:hover{filter:brightness(1.25)}.goto-btn:active{filter:brightness(.9)}.theme-toggle{background:linear-gradient(135deg, var(--paper-dark), var(--wood-bg));border:2px solid var(--grid-line);width:52px;height:52px;color:var(--ink-color);box-shadow:var(--neu-shadow-out), inset 0 1px 2px #ffffff4d;cursor:pointer;z-index:500;border-radius:50%;justify-content:center;align-items:center;transition:all .25s;display:flex;position:fixed;bottom:2rem;right:2rem}.theme-toggle:hover{box-shadow:var(--neu-shadow-hover);transform:translateY(-2px)scale(1.05)}.theme-toggle:active{box-shadow:var(--neu-shadow-in);transform:translateY(1px)scale(.97)}.theme-toggle svg{width:22px;height:22px;stroke:var(--ink-color);transition:stroke .25s}.calendar-grid{flex-direction:column;display:flex}.weekdays{text-align:center;letter-spacing:1px;text-transform:uppercase;color:var(--weekday-color);border-bottom:1px solid var(--grid-line);grid-template-columns:repeat(7,1fr);margin-bottom:.4rem;padding:.5rem 0;font-size:.75rem;font-weight:700;display:grid}.days{grid-template-columns:repeat(7,1fr);gap:6px;padding:4px 0;display:grid}.day{aspect-ratio:1;background:var(--paper-bg);color:var(--ink-color);cursor:pointer;box-shadow:var(--neu-shadow-out);-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;padding:.3rem;font-size:1rem;transition:box-shadow .2s,transform .15s,background .2s;display:flex;position:relative}.day:hover{box-shadow:var(--neu-shadow-hover);transform:translateY(-2px)}.day:active{box-shadow:var(--neu-shadow-in);transform:translateY(0)}.day span.date-num{z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;font-weight:600;display:flex;position:relative}.cell-indicators{pointer-events:none;justify-content:center;gap:2px;display:flex;position:absolute;bottom:3px;left:0;right:0}.cell-emoji{opacity:.9;font-size:.65rem;line-height:1}.cell-emoji sup{vertical-align:super;font-size:.55rem}.holiday-marker{opacity:.85;pointer-events:none;font-size:.7rem;position:absolute;top:4px;left:4px}.day.today{background:var(--paper-dark);box-shadow:var(--neu-shadow-in)}.day.today .date-num{color:var(--today-color);outline:2px solid var(--today-color);outline-offset:2px;border-radius:50%;font-weight:700}.day.other-month{color:var(--ink-light);opacity:.45;box-shadow:2px 2px 6px #a68c6e40,-2px -2px 6px #ffffff80}[data-theme=dark] .day.other-month{box-shadow:2px 2px 5px #0a0a1966,-2px -2px 5px #1e326426}.day.in-range,.day.in-hover-range{background:var(--range-strip);color:var(--ink-color);box-shadow:var(--neu-shadow-in);border-radius:4px}[data-theme=dark] .day.in-range,[data-theme=dark] .day.in-hover-range{box-shadow:var(--neu-shadow-in);background:#0288d12e}.day.range-start .date-num,.day.range-end .date-num,.day.range-hover-start .date-num,.day.range-hover-end .date-num{z-index:1;color:#fff;font-weight:700;position:relative}.day.range-start .date-num:before,.day.range-end .date-num:before,.day.range-hover-start .date-num:before,.day.range-hover-end .date-num:before{content:"";background:var(--range-dot);z-index:-1;width:28px;height:28px;box-shadow:0 2px 8px var(--range-dot-glow);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}[data-theme=dark] .day.range-start .date-num:before,[data-theme=dark] .day.range-end .date-num:before,[data-theme=dark] .day.range-hover-start .date-num:before,[data-theme=dark] .day.range-hover-end .date-num:before{background:#0288d1;box-shadow:0 2px 8px #0288d180}.day.range-start,.day.range-end{box-shadow:var(--neu-shadow-in)}.day.range-hover-start,.day.range-hover-end{box-shadow:var(--neu-shadow-in);opacity:.85}.calendar-notes{background:var(--notes-bg);border-left:3px solid var(--notes-border);background-image:repeating-linear-gradient(transparent, transparent 27px, var(--notes-line) 28px);background-attachment:local;border-radius:0 6px 6px 0;flex-direction:column;gap:12px;margin-top:1.5rem;padding:20px;display:flex;position:relative;transform:rotate(-.5deg);box-shadow:4px 6px 14px #00000038,0 1px #c8b45066}[data-theme=dark] .calendar-notes{background:var(--paper-dark);background-image:repeating-linear-gradient(#0000,#0000 27px,#648cdc26 28px);border-left:3px solid #0288d1;box-shadow:4px 6px 14px #0006,0 1px #0f3460}.notes-title{color:var(--notes-title-color);letter-spacing:.5px;border-bottom:2px solid var(--notes-line);margin:0;padding-bottom:8px;font-family:Georgia,Times New Roman,serif;font-size:1rem;font-weight:700}[data-theme=dark] .notes-title{color:#90caf9;border-bottom-color:#648cdc4d}[data-theme=dark] .no-event{color:#90caf966}[data-theme=dark] .event-item{color:#b0c8f0;background:#0f346080;border-left-color:#64b5f6}[data-theme=dark] .event-item:hover{background:#0f3460cc}[data-theme=dark] .add-event-btn-trigger{color:#64b5f6;border-color:#64b5f666}[data-theme=dark] .add-event-btn-trigger:hover{background:#64b5f614;border-color:#64b5f6}[data-theme=dark] .add-event-form{background:#0a142866;border-color:#648cdc33}[data-theme=dark] .submit-btn{color:#e3f2fd;background:#0288d1}[data-theme=dark] .submit-btn:hover{background:#0277bd}[data-theme=dark] .cancel-btn{color:#90caf9;border-color:#64b5f666}[data-theme=dark] .cancel-btn:hover{background:#64b5f60f;border-color:#64b5f6}.events-list{flex-direction:column;gap:8px;min-height:60px;max-height:200px;display:flex;overflow-y:auto}.events-list::-webkit-scrollbar{width:4px}.events-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:2px}.no-event{color:var(--ink-muted);padding:8px 4px;font-family:Georgia,serif;font-size:.95rem;font-style:italic}.event-item{background:var(--event-bg);border-left:3px solid var(--event-border);color:var(--ink-color);cursor:pointer;border-radius:0 4px 4px 0;justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;font-family:Georgia,serif;transition:background .15s,transform .15s;display:flex}.event-item:hover{background:var(--event-bg-hover);transform:translate(2px)}.event-item-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.event-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.event-item-time{opacity:.7;font-size:.8rem}.event-delete-hint{color:var(--event-delete);white-space:nowrap;opacity:0;font-size:.75rem;transition:opacity .15s}.event-item:hover .event-delete-hint{opacity:1}.add-event-btn-trigger{border:1.5px dashed var(--accent-border);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;align-self:flex-start;align-items:center;gap:6px;padding:6px 16px;font-family:Georgia,serif;font-size:.9rem;font-weight:700;transition:all .15s;display:flex}.add-event-btn-trigger:hover{background:var(--accent-subtle);border-color:var(--accent)}.add-event-form{background:#ffffff8c;border:1px solid #accce2b3;border-radius:6px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.event-input{background:var(--input-bg);border:1.5px solid var(--input-border);color:var(--input-color);caret-color:var(--input-caret);border-radius:6px;outline:none;width:100%;padding:8px 10px;font-family:Georgia,serif;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.event-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--input-bg-focus)}.event-input::placeholder{color:var(--input-placeholder);font-style:italic}[data-theme=dark] .event-input{color:#b0c8f0;caret-color:#64b5f6;background:#0f346080;border-color:#648cdc4d}[data-theme=dark] .event-input:focus{background:#0f3460cc;border-color:#64b5f6;box-shadow:0 0 0 3px #64b5f626}[data-theme=dark] .event-input::placeholder{color:#a0bef066}.time-inputs{gap:12px;display:flex}.event-input.half{flex:1;min-width:0}.event-input.full{width:100%}.form-actions{gap:8px;margin-top:4px;display:flex}.submit-btn{background:var(--btn-primary-bg);color:var(--btn-primary-color);cursor:pointer;border:none;border-radius:20px;flex:2;padding:8px;font-family:Georgia,serif;font-size:.9rem;font-weight:700;transition:all .15s;box-shadow:1px 2px 5px #0003}.submit-btn:hover{background:var(--accent-light);box-shadow:1px 3px 8px #0000004d}.cancel-btn{color:var(--btn-cancel-color);border:1.5px solid var(--btn-cancel-border);cursor:pointer;background:0 0;border-radius:20px;flex:1;padding:8px;font-family:Georgia,serif;font-size:.9rem;transition:all .15s}.cancel-btn:hover{border-color:var(--accent);background:var(--accent-subtle)}@media (width<=900px){.calendar-container{flex-direction:column;min-height:auto}.calendar-top{border-radius:4px 4px 0 0;width:100%;padding:16px 20px 32px;box-shadow:inset 0 -10px 20px -10px #00000014}.image-inset{aspect-ratio:4/3;max-width:280px;margin:0 auto}.month-hero-title{font-size:1.8rem}.calendar-bottom{border-radius:0 0 4px 4px;width:100%;padding:1.5rem;box-shadow:inset 0 10px 20px -10px #00000014}.calendar-notes{margin-top:1.2rem;transform:none}.spirals{flex-direction:row;justify-content:space-evenly;width:90%;height:24px;position:absolute;inset:auto auto -1px 5%;transform:translateY(50%)}.spiral{background:linear-gradient(90deg,#b0b0b0 0%,#fff 40%,#999 70%,#555 100%);border-radius:4px;width:14px;height:24px}.spiral:before,.spiral:after{display:none}}@media (width<=700px){body{align-items:flex-start;padding:.75rem}.calendar-container{min-height:unset;border-radius:12px;flex-direction:column;box-shadow:0 8px 24px #0003}.calendar-top{width:100%;box-shadow:none;min-height:unset;border-radius:12px 12px 0 0;justify-content:center;padding:16px 16px 0;display:flex}.image-inset{aspect-ratio:16/7;width:100%;max-width:340px;padding:8px;transform:none}.month-hero-title{font-size:1.6rem;bottom:8px}.spirals{display:none}.calendar-bottom{width:100%;box-shadow:none;border-radius:0 0 12px 12px;padding:1rem}.calendar-header{margin-bottom:.75rem;padding-bottom:.75rem}.current-month-year{letter-spacing:1.5px;font-size:1.2rem}.nav-btn{width:32px;height:32px}.calendar-controls{flex-wrap:nowrap;align-items:center;gap:6px;margin-bottom:.8rem;display:flex}.today-btn{white-space:nowrap;border-radius:16px;padding:6px 12px;font-size:.78rem}.date-input-wrapper{flex:1;min-width:0}.goto-label{display:none}.date-input{width:100%;min-width:0;padding:6px 8px;font-size:.82rem}.goto-btn{padding:6px 10px;font-size:.72rem}.weekdays{letter-spacing:0;margin-bottom:.2rem;padding:.4rem 0;font-size:.65rem}.days{gap:3px}.day{border-radius:8px;padding:0}.day span.date-num{width:22px;height:22px;font-size:.76rem}.day.range-start .date-num:before,.day.range-end .date-num:before,.day.range-hover-start .date-num:before,.day.range-hover-end .date-num:before{width:22px;height:22px}.cell-emoji{font-size:.48rem}.calendar-notes{border-radius:8px;margin-top:.75rem;padding:12px;transform:none}.notes-title{font-size:.88rem}.no-event{font-size:.82rem}.event-item{padding:5px 8px}.event-item-title{font-size:.85rem}.add-event-btn-trigger{padding:5px 12px;font-size:.78rem}.add-event-form{padding:10px}.time-inputs,.form-actions{flex-direction:column;gap:6px}.submit-btn,.cancel-btn{width:100%;padding:10px;font-size:.9rem}.pushpin{display:none}}@media (width<=400px){body{padding:.5rem}.calendar-bottom{padding:.75rem}.current-month-year{letter-spacing:1px;font-size:1rem}.days{gap:2px}.day span.date-num{width:20px;height:20px;font-size:.7rem}}.sticky-overlay{z-index:1000;cursor:default;position:fixed;inset:0}.sticky-note-popup{background:var(--sticky-bg);z-index:1001;background-image:repeating-linear-gradient(transparent, transparent 23px, var(--sticky-line) 24px);background-attachment:local;border-radius:4px 4px 12px;flex-direction:column;gap:8px;width:260px;padding:20px 18px 16px;display:flex;position:fixed;transform:rotate(-1deg);box-shadow:4px 6px 20px #00000059}@media (width<=480px){.sticky-note-popup{border-radius:12px;transform:none;box-shadow:0 -4px 24px #0000004d;width:auto!important;position:fixed!important;inset:auto 8px 8px!important}}.sticky-header{color:var(--ink-color);padding-right:24px;font-family:Handlee,Comic Sans MS,cursive,sans-serif;font-size:1rem;font-weight:700}.sticky-sublabel{color:#1a237e8c;margin-top:-4px;font-family:Georgia,serif;font-size:.75rem;font-style:italic}.sticky-textarea{resize:none;color:#1a237e;caret-color:#1a237e;background:0 0;border:none;outline:none;width:100%;height:120px;font-family:Handlee,Comic Sans MS,cursive,sans-serif;font-size:1.05rem;line-height:24px}.sticky-textarea::placeholder{color:#1a237e73}[data-theme=dark] .sticky-note-popup{background:#232d4b repeating-linear-gradient(#0000,#0000 23px,#648cdc2e 24px);box-shadow:4px 6px 20px #00000080}[data-theme=dark] .sticky-header{color:#90caf9}[data-theme=dark] .sticky-sublabel{color:#90caf980}[data-theme=dark] .sticky-textarea{color:#e8eaf6;caret-color:#90caf9}[data-theme=dark] .sticky-textarea::placeholder{color:#c8d2ff66}[data-theme=dark] .sticky-close{color:#90caf9}[data-theme=dark] .pushpin{background:radial-gradient(circle at 30% 30%,#64b5f6,#1565c0)}.sticky-close{color:#1a237e;cursor:pointer;opacity:.6;background:0 0;border:none;font-size:1.5rem;line-height:1;transition:opacity .2s;position:absolute;top:8px;right:12px}.sticky-close:hover{opacity:1}.sticky-anim-enter{opacity:0;animation:.2s cubic-bezier(.175,.885,.32,1.275) forwards stickyEnter}.sticky-anim-stable{opacity:1;transform:rotate(-1deg)scale(1)}.sticky-anim-exit{animation:.2s ease-in forwards stickyExit}@keyframes stickyEnter{0%{opacity:0;transform:scale(.8)rotate(-1deg)}to{opacity:1;transform:scale(1)rotate(-1deg)}}@keyframes stickyExit{0%{opacity:1;transform:scale(1)rotate(-1deg)}to{opacity:0;transform:scale(.9)rotate(-1deg)}}.pushpin{z-index:10;background:radial-gradient(circle at 30% 30%,#ff5252,#c62828);border-radius:50%;width:25px;height:25px;position:absolute;top:-10px;left:50%;transform:translate(-50%);box-shadow:inset -2px -2px 4px #0000004d,0 5px 8px #0009}.pushpin:after{content:"";z-index:-1;background:linear-gradient(90deg,#666,#ccc,#666);width:3px;height:10px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%);box-shadow:2px 2px 3px #00000080}
