@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";html,body{-webkit-font-smoothing:antialiased;background-color:#f5f7fa;width:100vw;height:100vh;margin:0;padding:0;font-family:Inter,sans-serif;overflow:hidden}*{box-sizing:border-box}.swipe-strip-container{background:linear-gradient(135deg,#fdfbfb 0%,#ebedee 100%);flex-direction:column;width:100vw;height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;display:flex;overflow:hidden}.swipe-strip-header{-webkit-backdrop-filter:blur(12px);z-index:10;padding:1rem 2rem;padding-top:max(1rem, env(safe-area-inset-top));background:#fff6;border-bottom:1px solid #ffffff4d;justify-content:space-between;align-items:center;display:flex;box-shadow:0 4px 30px #0000000d}.current-day-display{text-align:center;transition:transform .3s cubic-bezier(.25,.8,.25,1)}.current-day-display h1{background:linear-gradient(90deg,#ff416c,#ff4b2b);-webkit-text-fill-color:transparent;color:#ff416c;-webkit-background-clip:text;margin:0;font-size:1.5rem;font-weight:800}.current-day-display .subtitle{color:#888;text-transform:uppercase;letter-spacing:1px;font-size:.8rem;font-weight:500}.nav-button{cursor:pointer;color:#333;background:#ffffff80;border:1px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .3s;display:flex;box-shadow:0 4px 15px #0000000d}.nav-button:hover:not(:disabled){background:#fff;transform:scale(1.1);box-shadow:0 8px 25px #ff416c33}.nav-button:disabled{opacity:.3;cursor:not-allowed}.swipe-strip-content{flex:1;padding:2rem;position:relative;overflow-y:auto}.glass-card{-webkit-backdrop-filter:blur(8px);color:#555;text-align:center;background:#fff9;border:1px solid #fff9;border-radius:16px;padding:2rem;font-weight:500;animation:.3s ease-out slideFadeIn;box-shadow:0 8px 32px #1f268712}@keyframes slideFadeIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.mode-toggle-container{-webkit-backdrop-filter:blur(12px);z-index:9;background:#fff6;border-bottom:1px solid #ffffff4d;justify-content:center;align-items:center;gap:.75rem;padding:.5rem;display:flex}.mode-text{color:#888;text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:700}.toggle-label{width:44px;height:24px;display:inline-block;position:relative}.toggle-label input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:24px;transition:all .4s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0003}input:checked+.toggle-slider{background:linear-gradient(90deg,#ff416c,#ff4b2b)}input:checked+.toggle-slider:before{transform:translate(20px)}.fab-add-event{color:#fff;cursor:pointer;z-index:100;background:linear-gradient(90deg,#ff416c,#ff4b2b);border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:2rem;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:absolute;bottom:2rem;right:2rem;box-shadow:0 8px 25px #ff416c66}.fab-add-event:hover{transform:scale(1.1)rotate(90deg);box-shadow:0 12px 30px #ff416c99}.itinerary-timeline{flex-direction:column;gap:1.5rem;padding:1rem 0;display:flex;position:relative}.itinerary-timeline:before{content:"";z-index:1;background:linear-gradient(#ff416c33,#ff4b2bcc,#ff416c33);width:2px;position:absolute;top:0;bottom:0;left:60px}.timeline-item{z-index:2;gap:1.5rem;display:flex;position:relative}.timeline-time{color:#555;flex-direction:column;justify-content:flex-start;align-items:flex-end;width:70px;padding-top:.5rem;font-size:.85rem;font-weight:700;display:flex}.time-separator{color:#ff416c;margin:.2rem 0;font-size:.7rem}.time-end{color:#888;font-weight:500}.timeline-content{text-align:left;background:#ffffffb3;border-left:4px solid #ff416c;border-radius:16px;flex-direction:column;flex:1;gap:.5rem;padding:1.2rem;display:flex;box-shadow:0 4px 20px #0000000d}.event-title{color:#333;margin:0;font-size:1.2rem;font-weight:700}.event-actions{gap:.5rem;margin-top:.2rem;display:flex}.action-button{color:#ff416c;background:#ff416c1a;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.action-button:hover{color:#fff;background:#ff416c;transform:translateY(-2px);box-shadow:0 4px 10px #ff416c4d}.event-notes{color:#666;white-space:pre-wrap;background:#0000000a;border-radius:8px;margin-top:.5rem;margin-bottom:0;padding:.8rem;font-size:.9rem;line-height:1.4}.pop-in{animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards popIn}@keyframes popIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.event-attachments{flex-direction:column;gap:6px;margin-top:10px;display:flex}.attachment-card{color:#555;cursor:pointer;box-sizing:border-box;background:linear-gradient(135deg,#ff416c0d,#ff4b2b14);border:1px solid #ff416c1a;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .25s cubic-bezier(.25,.8,.25,1);display:flex}.attachment-card:hover{color:#ff416c;background:linear-gradient(135deg,#ff416c1f,#ff4b2b2e);border-color:#ff416c40;transform:translate(4px);box-shadow:0 2px 12px #ff416c1f}.attachment-card .attachment-icon{color:#ff416c;opacity:.7;flex-shrink:0}.attachment-card:hover .attachment-icon{opacity:1}.attachment-card .attachment-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.attachment-card .attachment-arrow{color:#ccc;flex-shrink:0;font-size:.9rem;transition:color .25s,transform .25s}.attachment-card:hover .attachment-arrow{color:#ff416c;transform:translate(3px)}.form-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#ffffffb3;justify-content:center;align-items:flex-end;padding:1rem;display:flex;position:absolute;inset:0}.slide-up{animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.form-container{text-align:left;background:#fff;border-radius:24px 24px 16px 16px;width:100%;max-width:500px;padding:2rem;box-shadow:0 -10px 40px #0000001a}.form-container h2{color:#333;margin-top:0;margin-bottom:1.5rem;font-size:1.5rem;font-weight:800}.add-event-form{flex-direction:column;gap:1.2rem;display:flex}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:#555;font-size:.85rem;font-weight:600}.form-group input,.form-group textarea{background:#f9f9f9;border:1px solid #ddd;border-radius:12px;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:all .3s}.form-group input:focus,.form-group textarea:focus{background:#fff;border-color:#ff416c;outline:none;box-shadow:0 0 0 3px #ff416c1a}.form-actions{gap:1rem;margin-top:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s}.btn-secondary{color:#555;background:#f0f0f0}.btn-secondary:hover{background:#e4e4e4}.btn-primary{color:#fff;background:linear-gradient(90deg,#ff416c,#ff4b2b);box-shadow:0 8px 20px #ff416c4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 25px #ff416c66}.date-strip-container{scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(12px);background:#fff6;border-bottom:1px solid #ffffff4d;gap:.5rem;padding:.5rem 1rem;display:flex;overflow-x:auto}.date-strip-container::-webkit-scrollbar{display:none}.date-strip-item{scroll-snap-align:center;cursor:pointer;color:#888;background:0 0;border:none;border-radius:16px;flex-direction:column;flex:none;justify-content:center;align-items:center;min-width:55px;height:65px;padding:.5rem;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:relative}.date-strip-item:hover{color:#555;background:#fff9}.date-strip-item.active{color:#ff416c;transform:translateY(-2px)}.date-weekday{text-transform:uppercase;margin-bottom:.2rem;font-size:.75rem;font-weight:700}.date-number{font-size:1.4rem;font-weight:800}.active-indicator{background:#ff416c;border-radius:50%;width:6px;height:6px;animation:.3s cubic-bezier(.175,.885,.32,1.275) forwards scaleIn;position:absolute;bottom:4px}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.month-divider{color:#ff416c;letter-spacing:.08em;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;-webkit-backdrop-filter:blur(6px);background:linear-gradient(135deg,#ff416c1f,#ff4b2b2e);border:1px solid #ff416c26;border-radius:20px;flex:none;justify-content:center;align-self:center;align-items:center;height:22px;margin:0 .1rem;padding:.25rem .6rem;font-size:.65rem;font-weight:800;animation:.4s cubic-bezier(.25,.8,.25,1) forwards monthFadeIn;display:flex}@keyframes monthFadeIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.date-strip-boundary{flex-direction:column;flex:none;justify-content:center;align-items:center;gap:4px;padding:0 2px;animation:.35s cubic-bezier(.25,.8,.25,1) forwards fadeSlideIn;display:flex}.date-strip-boundary.left{margin-right:4px}.date-strip-boundary.right{margin-left:4px}.boundary-btn{cursor:pointer;-webkit-backdrop-filter:blur(8px);border:1.5px solid #00000014;border-radius:10px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .25s cubic-bezier(.25,.8,.25,1);display:flex}.boundary-btn.add-btn{color:#2e7d32;background:linear-gradient(135deg,#4caf5026,#4caf5040);border-color:#4caf5033}.boundary-btn.add-btn:hover{background:linear-gradient(135deg,#4caf504d,#4caf5073);transform:scale(1.12);box-shadow:0 2px 12px #4caf5040}.boundary-btn.add-btn:active{transform:scale(.95)}.boundary-btn.remove-btn{color:#c62828;background:linear-gradient(135deg,#f443361a,#f443362e);border-color:#f4433626}.boundary-btn.remove-btn:hover{background:linear-gradient(135deg,#f4433640,#f4433666);transform:scale(1.12);box-shadow:0 2px 12px #f4433633}.boundary-btn.remove-btn:active{transform:scale(.95)}@keyframes fadeSlideIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
