.calendar-container{margin-bottom:3rem;background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;border:2px solid var(--color-border)}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.nav-button{background:var(--color-primary);color:#fff;border:2px solid var(--color-border);border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;white-space:nowrap}.nav-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.nav-button:active{transform:translateY(0)}.month-header{font-size:1.8rem;color:var(--color-primary);text-align:center;text-transform:capitalize;flex:1}.calendar-table{width:100%;border-collapse:collapse;table-layout:fixed}.calendar-table th,.calendar-table td{box-sizing:border-box}.calendar-table thead th{font-weight:700;color:var(--color-primary);text-align:center;padding:.75rem .25rem;font-size:.9rem;border-bottom:2px solid var(--color-border)}.calendar-table thead th:nth-child(2){background:#ff8c421a;border-radius:6px 6px 0 0}.calendar-table tbody td{padding:.25rem}.calendar-day{min-height:80px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:8px;padding:.5rem;position:relative;transition:all .3s ease;vertical-align:top;text-align:center}.calendar-day.empty{background:transparent;border:none}.calendar-day.tuesday{background:#ff8c420d;border-color:#ff8c424d}.calendar-day.has-post{background:var(--color-bg-secondary);border-color:var(--color-primary);border-width:2px}.calendar-day.has-post.future{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(255,140,66,.1) 100%);border-style:dashed}.calendar-day.has-post:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.day-number{font-size:.9rem;font-weight:700;color:var(--color-text-light);margin-bottom:.25rem}.calendar-day.has-post .day-number{color:var(--color-primary)}.day-posts{text-align:center;margin-top:.5rem}.post-indicator{text-decoration:none;display:inline-block;transition:transform .2s ease;margin:0 .125rem}.post-indicator:hover{transform:scale(1.3)}.post-emoji{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.legend{margin-top:2rem;padding:1.5rem;background:var(--color-bg-secondary);border-radius:12px;border:2px solid var(--color-border)}.legend-items{display:flex;flex-direction:column;gap:1rem}.legend-item{display:flex;align-items:center;gap:.75rem;color:var(--color-text);font-size:.95rem}.legend-box{width:40px;height:40px;border-radius:6px;border:2px solid var(--color-border)}.legend-box.has-post-box{background:var(--color-bg-secondary);border-color:var(--color-primary)}.legend-box.future-box{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(255,140,66,.1) 100%);border-color:var(--color-primary);border-style:dashed}.legend-box.tuesday-box{background:#ff8c420d;border-color:#ff8c424d}body[data-person=friend] .calendar-day.has-post{border-color:#b19cd9}body[data-person=friend] .calendar-day.has-post .day-number,body[data-person=friend] .month-header,body[data-person=friend] .calendar-table thead th{color:#b19cd9}body[data-person=friend] .calendar-table thead th:nth-child(2){background:#b19cd91a}body[data-person=friend] .calendar-day.tuesday{background:#b19cd90d;border-color:#b19cd94d}body[data-person=friend] .nav-button{background:#b19cd9}body[data-person=friend] .legend-box.has-post-box{border-color:#b19cd9}body[data-person=friend] .legend-box.future-box{border-color:#b19cd9;background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(177,156,217,.1) 100%)}body[data-person=friend] .legend-box.tuesday-box{background:#b19cd90d;border-color:#b19cd94d}body[data-person=friend] .calendar-day.has-post.future{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(177,156,217,.1) 100%)}@media(max-width:768px){.calendar-table thead th{padding:.5rem .125rem;font-size:.75rem}.calendar-table tbody td{padding:.125rem}.calendar-day{min-height:70px;padding:.25rem}.day-number{font-size:.75rem}.post-emoji{font-size:1.1rem}.calendar-header{padding:.25rem;font-size:.75rem}.month-header{font-size:1.4rem;order:-1;width:100%;margin-bottom:.5rem}.nav-button{padding:.5rem 1rem;font-size:.9rem}.calendar-nav{gap:.5rem}.legend-items{font-size:.85rem}.legend-box{width:30px;height:30px}}
