@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&family=Noto+Sans+KR:wght@300;400;600;700&display=swap";:root{--bg:#0c0d14;--surface:#121420b3;--surface-hover:#1c1e30d9;--border:#ffffff14;--border-focus:#6c5ce799;--text-primary:#f0f2ff;--text-secondary:#8b90b0;--text-muted:#555a7a;--accent:#6c5ce7;--accent-2:#a29bfe;--accent-glow:#6c5ce759;--success:#00b894;--error:#e17055;--warning:#fdcb6e;--radius-sm:10px;--radius-md:16px;--radius-lg:22px;--shadow:0 8px 32px #00000080;--transition:.25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;min-height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Outfit,Noto Sans KR,sans-serif}body{background:radial-gradient(ellipse at 10% 20%, #6c5ce71f 0%, transparent 60%), radial-gradient(ellipse at 90% 80%, #00b89414 0%, transparent 60%), var(--bg)}#root,.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{text-align:center;padding:2rem 2rem 1rem}.header-inner{max-width:900px;margin:0 auto}.header-brand{justify-content:center;align-items:center;gap:.6rem;margin-bottom:.4rem;display:flex}.header-icon{font-size:2rem}.app-header h1{letter-spacing:-1px;background:linear-gradient(135deg, #fff 0%, var(--accent-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800}.header-subtitle{color:var(--text-secondary);letter-spacing:.5px;font-size:.95rem}.mode-toggle{justify-content:center;gap:.5rem;padding:.75rem 1rem;display:flex}.mode-toggle-inner{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);gap:.3rem;padding:.35rem;display:flex}.mode-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-family:inherit;font-size:.95rem;font-weight:600;display:flex}.mode-btn:hover{color:var(--text-primary);background:#ffffff0f}.mode-btn.active{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;box-shadow:0 4px 16px var(--accent-glow)}.mode-btn-icon{font-size:1.1rem}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:0 1rem 2rem}.week-view{width:100%}.week-grid{grid-template-columns:repeat(7,1fr);gap:.75rem;padding-bottom:.5rem;display:grid;overflow-x:auto}@media (width<=900px){.week-grid{grid-template-columns:repeat(4,minmax(160px,1fr))}}@media (width<=600px){.week-grid{grid-template-columns:repeat(2,1fr)}}.travel-view{width:100%}.travel-schedule-bar{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.schedule-select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex:1;padding:.65rem 1rem;font-family:inherit;font-size:.95rem}.schedule-select:focus{border-color:var(--border-focus);outline:none}.new-travel-btn{border:1px solid var(--border-focus);border-radius:var(--radius-sm);color:var(--accent-2);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:#6c5ce733;padding:.65rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600}.new-travel-btn:hover{color:#fff;background:#6c5ce759}.day-tabs{gap:.4rem;margin-bottom:1rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.day-tab{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600}.day-tab:hover{color:var(--text-primary);border-color:#ffffff26}.day-tab.active{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;box-shadow:0 3px 12px var(--accent-glow);border-color:#0000}.day-tab.completed{color:var(--success);border-color:#00b8944d}.day-tab.completed.active{background:linear-gradient(135deg, var(--success), #55efc4);color:#fff;box-shadow:0 3px 12px #00b89466}.travel-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:40vh;display:flex}.travel-empty-icon{font-size:3.5rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.travel-empty h2{font-size:1.5rem;font-weight:700}.travel-empty p{color:var(--text-secondary);font-size:.95rem}.create-travel-btn{background:linear-gradient(135deg, var(--accent), var(--accent-2));border-radius:var(--radius-md);color:#fff;cursor:pointer;box-shadow:0 6px 20px var(--accent-glow);transition:all var(--transition);border:none;padding:.8rem 2rem;font-family:inherit;font-size:1rem;font-weight:700}.create-travel-btn:hover:not(:disabled){box-shadow:0 10px 28px var(--accent-glow);transform:translateY(-2px)}.create-travel-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.travel-create-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;gap:.75rem;max-width:440px;margin:2rem auto;padding:2rem;display:flex}.travel-create-form h2{margin-bottom:.5rem;font-size:1.4rem;font-weight:700}.travel-create-form label{color:var(--text-secondary);font-size:.85rem}.travel-create-form input[type=text],.travel-create-form input[type=number],.travel-create-form input[type=date]{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#0000004d;padding:.75rem 1rem;font-family:inherit;font-size:1rem}.travel-create-form input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.cancel-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;flex:1;padding:.75rem;font-family:inherit;font-size:.95rem}.cancel-btn:hover{color:var(--text-primary);background:#ffffff0f}.schedule-list-view{width:100%;margin:1rem 0}.schedule-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:.5rem;display:grid}.schedule-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.schedule-card:hover{background:var(--surface-hover);border-color:#6c5ce766;transform:translateY(-4px);box-shadow:0 8px 24px #0006}.card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.card-header h3{color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:700}.latest-badge{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;white-space:nowrap;border-radius:99px;padding:.2rem .6rem;font-size:.7rem;font-weight:700}.latest-glow{box-shadow:0 0 20px var(--accent-glow);border-color:#6c5ce799;animation:3s ease-in-out infinite alternate glow}@keyframes glow{0%{box-shadow:0 0 15px var(--accent-glow)}to{box-shadow:0 0 35px #6c5ce7b3}}.schedule-card p{color:var(--text-secondary);margin:0;font-size:.9rem}.add-card{background:#ffffff05;border-style:dashed;justify-content:center;align-items:center;min-height:120px}.add-card:hover{border-color:var(--accent);background:#6c5ce71a}.add-card h3{color:var(--accent-2);margin:0;font-weight:600}.detail-header{align-items:center;gap:1.5rem;margin-bottom:1.5rem;display:flex}.detail-header h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:700}.back-to-list-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:#ffffff0d;padding:.5rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600}.back-to-list-btn:hover{color:var(--text-primary);background:#ffffff1a}.timeline-column{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);min-height:280px;transition:border-color var(--transition);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.timeline-column:hover{border-color:#ffffff24}.timeline-header{align-items:center;gap:.5rem;display:flex}.timeline-day-label{color:var(--accent-2);letter-spacing:1px;text-transform:uppercase;flex-shrink:0;font-size:.85rem;font-weight:700}.timeline-progress{background:#ffffff12;border-radius:99px;flex:1;height:4px;overflow:hidden}.timeline-progress-bar{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:99px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.timeline-count{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.timeline-tasks{flex-direction:column;flex:1;gap:.5rem;display:flex}.timeline-empty{color:var(--text-muted);text-align:center;padding:1rem 0;font-size:.85rem}.timeline-add-btn{border-radius:var(--radius-sm);color:#a29bfeb3;cursor:pointer;width:100%;transition:all var(--transition);background:0 0;border:1px dashed #6c5ce759;padding:.5rem;font-family:inherit;font-size:.82rem}.timeline-add-btn:hover{border-color:var(--accent);color:var(--accent-2);background:#6c5ce71a}.timeline-add-form{flex-direction:column;gap:.4rem;display:flex}.add-time-input,.add-title-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#00000059;padding:.5rem .75rem;font-family:inherit;font-size:.85rem}.add-time-input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-size:.8rem}.add-title-input:focus,.add-time-input:focus{border-color:var(--border-focus);outline:none}.add-form-actions{gap:.4rem;display:flex}.add-confirm-btn,.add-cancel-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);flex:1;padding:.45rem;font-family:inherit;font-size:.82rem;font-weight:600}.add-confirm-btn{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border:none}.add-confirm-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.add-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.add-cancel-btn{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.add-cancel-btn:hover{color:var(--text-primary);background:#ffffff0f}.task-card{border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition);background:#ffffff08;flex-direction:column;padding:.55rem .65rem;display:flex;position:relative}.task-card-header{align-items:center;gap:.4rem;width:100%;display:flex}.task-card:hover{background:#ffffff0f;border-color:#ffffff1f}.task-card.done{opacity:.5}.task-card.done .task-title{color:var(--text-muted);text-decoration:line-through}.task-card.busy{pointer-events:none;opacity:.6}.task-time{color:var(--accent-2);white-space:nowrap;min-width:34px;font-size:.7rem;font-weight:600}.task-check{cursor:pointer;background:0 0;border:none;flex-shrink:0;font-size:1rem;line-height:1;transition:transform .15s}.task-check:hover{transform:scale(1.2)}.task-title{color:var(--text-primary);word-break:break-all;cursor:pointer;flex:1;min-width:0;font-size:.85rem}.task-memo{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:.72rem;display:block;overflow:hidden}.task-badge{border-radius:99px;flex-shrink:0;padding:.1rem .35rem;font-size:.65rem;font-weight:700}.task-badge.repeat{color:var(--accent-2);background:#6c5ce740;border:1px solid #6c5ce74d}.task-edit-input{border:1px solid var(--border-focus);color:var(--text-primary);background:#0006;border-radius:6px;flex:1;padding:.25rem .5rem;font-family:inherit;font-size:.85rem}.task-edit-input:focus{outline:none}.task-actions{flex-shrink:0;gap:.2rem;display:flex}.task-action-btn{cursor:pointer;transition:all var(--transition);border:none;border-radius:6px;padding:.2rem .4rem;font-family:inherit;font-size:.72rem;font-weight:600}.task-action-btn.edit,.task-action-btn.delete{color:var(--text-muted);background:0 0;font-size:.85rem}.task-action-btn.edit:hover{color:var(--accent-2)}.task-action-btn.delete:hover{color:var(--error)}.task-action-btn.camera,.task-action-btn.gallery{color:var(--text-muted);background:0 0;font-size:.85rem}.task-action-btn.camera:hover,.task-action-btn.gallery:hover{color:var(--success)}.task-action-btn:disabled{opacity:.3;cursor:not-allowed}.task-image-gallery{border-top:1px dashed #ffffff1a;gap:.5rem;width:100%;margin-top:.5rem;padding-top:.5rem;display:flex;overflow-x:auto}.task-image-thumb-wrapper{border-radius:var(--radius-sm);border:1px solid #ffffff1a;flex-shrink:0;width:60px;height:60px;position:relative;overflow:hidden}.task-image-thumb{object-fit:cover;width:100%;height:100%}.task-image-delete{color:#fff;cursor:pointer;width:18px;height:18px;transition:background var(--transition);background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.task-image-delete:hover{background:var(--error)}.image-viewer-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:10000;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.image-viewer-img{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);width:90vw;max-width:500px;animation:.2s cubic-bezier(.16,1,.3,1) zoomIn;box-shadow:0 10px 40px #00000080}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.task-action-btn.save{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff}.task-action-btn.cancel{color:var(--text-secondary);background:#ffffff0f}.view-loading{min-height:30vh;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1rem;animation:1.5s ease-in-out infinite pulse;display:flex}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;gap:.6rem;width:max-content;max-width:90vw;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.toast-item{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow), inset 0 1px 0 #ffffff0d;color:#fff;cursor:pointer;pointer-events:auto;white-space:nowrap;border:1px solid #ffffff1a;align-items:center;gap:.65rem;padding:.75rem 1.2rem;font-size:.9rem;font-weight:500;animation:.3s cubic-bezier(.16,1,.3,1) forwards toastIn;display:flex}.toast-icon{flex-shrink:0;font-size:1.1rem}.toast-msg{line-height:1.4}.toast-success{background:#00b89440;border-color:#00b89459}.toast-error{background:#e1705540;border-color:#e1705559}.toast-info{background:#6c5ce74d;border-color:#6c5ce766}.toast-loading{background:#141624cc;border-color:#ffffff1a}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.timeline-history-view{padding-left:24px;position:relative}.timeline-history-view:before{content:"";background:linear-gradient(to bottom, var(--accent), #ffffff1a);border-radius:2px;width:2px;position:absolute;top:10px;bottom:10px;left:7px}.timeline-history-view .task-wrapper{position:relative}.history-dot{background:var(--bg);border:2px solid var(--accent-2);z-index:1;width:10px;height:10px;box-shadow:0 0 10px var(--accent-glow);transition:all var(--transition);border-radius:50%;position:absolute;top:50%;left:-21px;transform:translateY(-50%)}.timeline-history-view .task-wrapper:hover .history-dot{background:var(--accent);box-shadow:0 0 15px #6c5ce7cc}.task-card.warning,.history-dot.warning{border-color:#fdcb6e;box-shadow:0 0 15px #fdcb6e99}.task-card.critical,.history-dot.critical{border-color:#ff7675;box-shadow:0 0 15px #ff767599}.schedule-card.critical-glow{border:1px solid #ff767580;box-shadow:0 0 15px #ff767599}.popup-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.popup-content{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;width:90%;max-width:320px;padding:1.5rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) toastIn;box-shadow:0 8px 32px #00000080}.popup-content p{margin:0 0 1.5rem;font-size:1.1rem;font-weight:500}.popup-actions{justify-content:center;gap:10px;display:flex}.popup-btn{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.2rem;font-weight:700;transition:all .2s}.popup-btn.confirm{background:var(--error);color:#fff}.popup-btn.confirm:hover{background:#ff5252}.popup-btn.cancel{color:var(--text);background:#ffffff1a}.popup-btn.cancel:hover{background:#fff3}.schedule-delete-btn{color:var(--error);cursor:pointer;background:#ff767526;border:1px solid #ff76754d;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.85rem;transition:all .2s;display:flex}.schedule-delete-btn:hover{background:var(--error);color:#fff}.custom-select-container{-webkit-user-select:none;user-select:none;position:relative}.custom-select-trigger{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s;display:flex}.custom-select-trigger:focus,.custom-select-trigger:hover{border-color:var(--accent);outline:none}.custom-select-trigger .arrow{color:var(--text-muted);font-size:.8rem}.custom-select-dropdown{background:var(--surface);border:1px solid var(--border);z-index:1000;border-radius:8px;max-height:420px;margin:0;padding:0;list-style:none;animation:.15s ease-out fadeIn;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0006}.custom-select-dropdown::-webkit-scrollbar{width:8px}.custom-select-dropdown::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.custom-select-option{cursor:pointer;padding:.6rem 1rem;transition:background .15s}.custom-select-option:hover{background:#ffffff0d}.custom-select-option.selected{background:var(--accent);color:#fff}
