:root{--bg-color:#faf9f5;--card-bg:#fff;--text-main:#2b2a27;--text-muted:#807e77;--accent-red:#c94a29;--accent-gold:#d1a153;--border-light:#2b2a2714;--shadow-soft:0 10px 30px -10px #2b2a270f, 0 1px 3px #2b2a2705;--transition-smooth:all .4s cubic-bezier(.16, 1, .3, 1);--transition-fast:all .2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;justify-content:center;align-items:flex-start;min-height:100vh;padding:20px 10px;font-family:Outfit,Noto Sans KR,sans-serif;line-height:1.5;display:flex;overflow-x:hidden}.font-serif{font-family:Playfair Display,serif}.app-container{background-color:var(--card-bg);width:100%;max-width:480px;box-shadow:var(--shadow-soft);border:1px solid var(--border-light);border-radius:24px;flex-direction:column;animation:.8s cubic-bezier(.16,1,.3,1) fadeIn;display:flex;position:relative;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.image-section{aspect-ratio:4/3;background-color:#f3f1eb;justify-content:center;align-items:center;width:100%;padding:20px;display:flex;position:relative;overflow:hidden}.calendar-image{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;transition:var(--transition-smooth);border-radius:6px;box-shadow:0 6px 20px #2b2a271a}.image-section:hover .calendar-image{transform:scale(1.02)}.image-loading{color:var(--text-muted);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#f6f5f0cc;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;inset:0}.image-overlay-text{color:#fff;text-shadow:0 2px 10px #0000004d;pointer-events:none;position:absolute;bottom:20px;left:24px}.image-overlay-text .moment-title{font-family:Playfair Display,serif;font-size:24px;font-style:italic;font-weight:500}.refresh-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;color:var(--text-main);transition:var(--transition-fast);z-index:10;background:#ffffffbf;border:1px solid #ffffff4d;border-radius:30px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;display:flex;position:absolute;top:20px;right:20px;box-shadow:0 4px 15px #0000000d}.refresh-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.refresh-btn svg{transition:transform .6s}.refresh-btn:active svg{transform:rotate(360deg)}.calendar-section{flex-direction:column;flex-grow:1;padding:30px 24px 24px;display:flex}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.date-selector-trigger{cursor:pointer;text-align:left;transition:var(--transition-fast);background:0 0;border:none;border-radius:8px;flex-direction:column;padding:4px 8px;display:flex}.date-selector-trigger:hover{background-color:#2b2a270a}.date-selector-trigger .year-label{color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-size:16px;font-weight:300}.date-selector-trigger .month-label{color:var(--text-main);align-items:center;gap:6px;font-family:Playfair Display,serif;font-size:32px;font-weight:600;line-height:1.1;display:flex}.date-selector-trigger .month-label svg{opacity:.4;width:14px;height:14px;transition:var(--transition-fast)}.date-selector-trigger:hover .month-label svg{opacity:.8;transform:translateY(2px)}.nav-buttons{gap:8px;display:flex}.nav-btn{border:1px solid var(--border-light);cursor:pointer;width:38px;height:38px;transition:var(--transition-fast);color:var(--text-main);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex}.nav-btn:hover{background-color:var(--text-main);color:#fff;border-color:var(--text-main)}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:8px 4px;margin-bottom:20px;display:grid}.weekday-header{text-transform:uppercase;color:var(--text-muted);text-align:center;border-bottom:1px solid var(--border-light);letter-spacing:1px;padding-bottom:12px;font-size:11px;font-weight:600}.weekday-header.sunday{color:var(--accent-red)}.calendar-day-cell{min-height:52px;transition:var(--transition-fast);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:flex-start;align-items:center;padding:4px 2px;display:flex;position:relative}.calendar-day-cell:hover:not(.empty-cell){background-color:#2b2a2708}.calendar-day-cell.today{background-color:#d1a15314}.day-number{color:var(--text-main);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-family:Outfit,sans-serif;font-size:14px;font-weight:400;display:flex}.calendar-day-cell.today .day-number{background-color:var(--accent-gold);color:#fff;font-weight:600}.calendar-day-cell.sunday .day-number,.calendar-day-cell.holiday .day-number{color:var(--accent-red);font-weight:500}.holiday-name{color:var(--accent-red);text-align:center;white-space:nowrap;text-overflow:ellipsis;width:100%;margin-top:2px;padding:0 2px;font-size:8px;font-weight:500;overflow:hidden}.today-dot{background-color:var(--accent-gold);border-radius:50%;width:4px;height:4px;margin-top:4px}.empty-cell{cursor:default}.calendar-footer{border-top:1px solid var(--border-light);background-color:#faf9f580;justify-content:center;align-items:center;padding:16px 24px;display:flex}.view-toggle-btn{border:1px solid var(--border-light);cursor:pointer;color:var(--text-main);transition:var(--transition-fast);background:0 0;border-radius:30px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.view-toggle-btn:hover{background-color:var(--text-main);color:#fff;border-color:var(--text-main)}.view-toggle-btn svg{width:16px;height:16px}.year-view-container{flex-direction:column;gap:20px;max-height:80vh;padding:24px;display:flex;overflow-y:auto}.year-view-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.year-view-title{font-family:Playfair Display,serif;font-size:32px;font-weight:700}.year-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=400px){.year-grid{grid-template-columns:repeat(2,1fr)}}.mini-month-card{transition:var(--transition-fast);cursor:pointer;background-color:#faf9f6;border:1px solid #2b2a270d;border-radius:12px;padding:10px}.mini-month-card:hover{border-color:#2b2a2726;transform:translateY(-2px);box-shadow:0 4px 12px #2b2a270a}.mini-month-name{text-transform:uppercase;color:var(--text-main);border-bottom:1px solid #2b2a270d;margin-bottom:6px;padding-bottom:4px;font-family:Playfair Display,serif;font-size:13px;font-weight:700}.mini-month-grid{grid-template-columns:repeat(7,1fr);gap:2px 1px;display:grid}.mini-weekday{text-align:center;color:var(--text-muted);font-size:7px;font-weight:600}.mini-weekday.sun{color:var(--accent-red)}.mini-day{text-align:center;color:var(--text-main);justify-content:center;align-items:center;height:12px;font-size:8px;display:flex}.mini-day.sun,.mini-day.holiday{color:var(--accent-red);font-weight:500}.mini-day.empty{visibility:hidden}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background-color:#2b2a2766;justify-content:center;align-items:flex-end;animation:.3s fadeInOverlay;display:flex;position:absolute;inset:0}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--card-bg);border-radius:24px 24px 0 0;flex-direction:column;width:100%;max-height:85%;padding:24px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex;transform:translateY(0);box-shadow:0 -10px 40px #00000026}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{color:var(--text-main);font-size:18px;font-weight:600}.close-btn{cursor:pointer;color:var(--text-muted);transition:var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex}.close-btn:hover{color:var(--text-main);background-color:#2b2a270d}.picker-grid{flex-grow:1;gap:20px;margin-bottom:20px;display:flex;overflow:hidden}.picker-column{flex-direction:column;flex:1;gap:8px;max-height:250px;padding-right:4px;display:flex;overflow-y:auto}.picker-column::-webkit-scrollbar{width:4px}.year-view-container::-webkit-scrollbar{width:4px}.picker-column::-webkit-scrollbar-track{background:0 0}.year-view-container::-webkit-scrollbar-track{background:0 0}.picker-column::-webkit-scrollbar-thumb{background:#2b2a271a;border-radius:4px}.year-view-container::-webkit-scrollbar-thumb{background:#2b2a271a;border-radius:4px}.picker-option{text-align:center;cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;border-radius:10px;padding:12px;font-size:15px;font-weight:500}.picker-option:hover{background-color:#2b2a2708}.picker-option.selected{background-color:var(--text-main);color:#fff}.picker-confirm-btn{background-color:var(--text-main);color:#fff;cursor:pointer;transition:var(--transition-fast);text-align:center;border:none;border-radius:12px;padding:14px;font-size:15px;font-weight:600}.picker-confirm-btn:hover{opacity:.9;transform:translateY(-1px)}
