.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#fdf6ee,#fae8d3)}.login-card{background:#fff;border-radius:24px;padding:44px 36px;width:100%;max-width:400px;box-shadow:0 8px 40px #0000001a}.login-emoji{font-size:52px;text-align:center;margin-bottom:12px}.login-title{font-family:Lora,serif;font-size:36px;text-align:center;color:var(--ink);margin-bottom:8px}.login-sub{font-size:15px;color:var(--muted);text-align:center;line-height:1.55;margin-bottom:28px}.app-header{background:var(--ink);display:flex;align-items:center;justify-content:space-between;padding:12px 20px;position:sticky;top:0;z-index:10}.brand{font-family:Lora,serif;font-size:22px;font-weight:700;color:#fff;letter-spacing:-.3px}.brand-accent{color:var(--amber)}.user-chip{display:flex;align-items:center;gap:8px;background:#ffffff1a;border-radius:999px;padding:4px 12px 4px 5px;border:none;cursor:pointer;transition:background .15s}.user-chip:hover{background:#ffffff2e}.user-name{color:#ccc;font-size:14px;font-weight:500}.screen{display:flex;flex-direction:column;height:100%;overflow:hidden}.cal-body{flex:1;overflow-y:auto;padding:16px 16px 32px;-webkit-overflow-scrolling:touch}.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.month-name{font-family:Lora,serif;font-size:26px;font-weight:700;color:var(--ink);line-height:1}.month-year{font-size:14px;color:#aaa;margin-top:2px}.nav-btn{width:34px;height:34px;border-radius:50%;border:2px solid var(--border);background:var(--white);font-size:18px;color:#555;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.nav-btn:hover{border-color:var(--ink);background:var(--ink);color:#fff}.add-btn{background:var(--amber);color:#fff;border:none;border-radius:999px;padding:7px 16px;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #f5a62359}.add-btn:hover{background:#e09610}.day-labels{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.day-label{text-align:center;font-size:11px;font-weight:700;color:#bbb;text-transform:uppercase;letter-spacing:.4px;padding:4px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.cal-cell{min-height:72px;background:var(--white);border-radius:10px;padding:6px 5px 4px;cursor:pointer;border:2px solid transparent;transition:border-color .15s,background .15s;overflow:hidden}.cal-cell:hover{border-color:var(--amber);background:#fffbf4}.cal-cell.today{border-color:var(--amber)}.cell-num{font-size:12px;font-weight:600;color:#aaa;margin-bottom:4px;line-height:1}.today-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--amber);color:#fff;border-radius:50%;font-size:11px}.cell-dots{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:2px}.event-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;cursor:pointer}.cell-label{font-size:10px;font-weight:600;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.upcoming-section{margin-top:24px}.section-heading{font-size:11px;font-weight:700;color:#bbb;text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px}.event-list{display:flex;flex-direction:column;gap:8px}.event-row{display:flex;background:var(--white);border-radius:12px;overflow:hidden;border:none;text-align:left;cursor:pointer;transition:transform .12s;box-shadow:0 1px 4px #0000000d;width:100%}.event-row:active{transform:scale(.985)}.event-row-accent{width:5px;flex-shrink:0}.event-row-body{padding:12px 14px;flex:1;min-width:0}.event-row-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.event-row-title{font-size:15px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-row-meta{font-size:13px;color:var(--muted);display:flex;gap:4px}.going-count{color:var(--green);font-weight:600}.rsvp-badge{font-size:15px;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 0;color:#ccc;font-size:15px}.empty-icon{font-size:32px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:100;display:flex;align-items:flex-end;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet{background:var(--white);border-radius:20px 20px 0 0;width:100%;max-height:92vh;display:flex;flex-direction:column;padding-bottom:var(--safe-bottom)}.sheet-handle{width:36px;height:5px;background:#e0d8ce;border-radius:999px;align-self:center;margin-top:10px;flex-shrink:0}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 0;flex-shrink:0}.sheet-title{font-family:Lora,serif;font-size:22px;color:var(--ink);flex:1}.close-btn{width:30px;height:30px;border-radius:50%;background:#f0ebe4;display:flex;align-items:center;justify-content:center;font-size:13px;color:#666;cursor:pointer;flex-shrink:0;border:none;transition:background .15s}.close-btn:hover{background:#e0d8ce}.sheet-body{padding:16px 20px 24px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.detail-date{display:inline-block;background:var(--amber-light);color:var(--amber-dark);font-size:12px;font-weight:700;border-radius:6px;padding:3px 10px;margin-bottom:10px}.detail-title{font-family:Lora,serif;font-size:26px;color:var(--ink);margin-bottom:8px;line-height:1.25}.detail-meta{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--muted);margin-bottom:4px}.detail-desc{background:var(--surface);border-radius:10px;padding:12px 14px;font-size:15px;color:#555;line-height:1.6;margin-top:14px}.rsvp-row{display:flex;gap:8px}.rsvp-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border-radius:12px;border:2px solid var(--border);background:var(--white);font-size:12px;font-weight:600;color:#666;cursor:pointer;transition:all .15s}.rsvp-btn span:first-child{font-size:20px}.rsvp-active{color:var(--ink)}.attendee-list{display:flex;flex-wrap:wrap;gap:8px}.attendee-chip{display:flex;align-items:center;gap:6px;background:#f5f0ea;border-radius:999px;padding:4px 12px 4px 5px;font-size:13px;font-weight:600;color:#444}.muted{color:#bbb;font-size:14px}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1;background:#f0ebe4}.photo-img{width:100%;height:100%;object-fit:cover;display:block}.photo-by{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#0000008c);padding:14px 6px 5px;color:#fff;font-size:10px;font-weight:700}.photo-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;aspect-ratio:1;border-radius:10px;border:2px dashed #d8cec2;cursor:pointer;font-size:11px;font-weight:600;color:#bbb;transition:all .15s}.photo-add:hover{border-color:var(--amber);color:var(--amber-dark);background:#fffbf4}.delete-btn{display:block;margin:28px auto 0;background:#e8485510;color:var(--red);border:none;border-radius:10px;padding:9px 18px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}.delete-btn:hover{background:#e8485520}.text-input{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:12px;font-size:15px;color:var(--ink);background:var(--surface);outline:none;transition:border-color .2s;display:block;margin-bottom:14px}.text-input:focus{border-color:var(--amber);background:var(--white)}textarea.text-input{resize:vertical;min-height:80px}.field-label{display:block;font-size:12px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn-primary{padding:14px;background:var(--ink);color:var(--white);border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;display:block}.btn-primary:hover{background:#333}.btn-primary:disabled{opacity:.5;cursor:default}.cal-cell.past{opacity:.5}.icon-btn{background:#ffffff1a;border:none;border-radius:8px;padding:5px 8px;font-size:18px;cursor:pointer;transition:background .15s}.icon-btn:hover{background:#fff3}.tab-row{display:flex;gap:6px;margin-top:20px;margin-bottom:14px;border-bottom:2px solid var(--border);padding-bottom:0}.tab-btn{padding:8px 14px;border:none;background:none;font-size:14px;font-weight:600;color:#aaa;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:5px;white-space:nowrap}.tab-btn:hover{color:var(--ink)}.tab-active{color:var(--ink)!important;border-bottom-color:var(--amber)!important}.tab-count{background:var(--amber);color:#fff;border-radius:999px;font-size:10px;font-weight:700;padding:1px 6px;min-width:18px;text-align:center}.meta-icon{font-size:12px;color:#aaa}.memory-row{align-items:flex-start}.memory-thumb{width:56px;height:56px;flex-shrink:0;background-size:cover;background-position:center}.memory-who{display:flex;gap:3px;margin-top:6px;flex-wrap:wrap}.memory-more{font-size:11px;color:#aaa;align-self:center}.bring-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.bring-item{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:10px;padding:10px 12px;transition:background .15s}.bring-item.claimed{background:#f0faf4}.bring-check{font-size:20px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}.bring-text{flex:1;min-width:0}.bring-name{font-size:15px;font-weight:600;color:var(--ink);display:block}.claimed-text{color:#aaa;text-decoration:line-through}.bring-claimer{font-size:12px;color:var(--green);font-weight:500;display:block;margin-top:1px}.bring-delete{background:none;border:none;color:#ccc;font-size:14px;cursor:pointer;padding:2px 4px;flex-shrink:0}.bring-delete:hover{color:var(--red)}.bring-add-row{display:flex;gap:8px;align-items:center;margin-top:4px}.add-item-btn{padding:12px 16px;background:var(--ink);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .15s}.add-item-btn:hover{background:#333}.add-item-btn:disabled{opacity:.4;cursor:default}.comments-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.comment{background:var(--surface);border-radius:12px;padding:10px 12px}.my-comment{background:#fff8ec}.comment-header{display:flex;align-items:center;gap:7px;margin-bottom:6px}.comment-author{font-size:13px;font-weight:700;color:var(--ink)}.comment-time{font-size:11px;color:#bbb;margin-left:auto}.comment-text{font-size:14px;color:#444;line-height:1.5}.comment-input-row{display:flex;gap:8px;align-items:center}.login-error{color:var(--red);font-size:13px;font-weight:600;margin-top:-8px;margin-bottom:8px}@media (max-width: 380px){.cal-cell{min-height:58px}.cell-label{display:none}.photo-grid{grid-template-columns:repeat(2,1fr)}.tab-btn{padding:8px 10px;font-size:13px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #FDF6EE;--white: #ffffff;--ink: #1a1a1a;--amber: #F5A623;--amber-light: #F5A62318;--amber-dark: #c47d00;--green: #4CAF7D;--red: #E84855;--muted: #888;--border: #e8e0d5;--surface: #fafaf8;--shadow: 0 4px 24px rgba(0,0,0,.08);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{height:100%;background:var(--cream);font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}body{padding-top:var(--safe-top)}input,textarea,button,select{font-family:DM Sans,sans-serif}button{cursor:pointer;border:none;background:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#e0d0b8;border-radius:2px}*{-webkit-tap-highlight-color:transparent}.scroll-y{overflow-y:auto;-webkit-overflow-scrolling:touch}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fade-up{animation:fadeUp .25s ease both}
