.cal-page{padding:24px;background:var(--cd-bg);color:var(--cd-fg);min-height:100%}.cal-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:20px}.cal-header-left h2{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:700;color:var(--cd-fg);margin:0 0 4px}.cal-header-left p{color:var(--cd-muted-fg);font-size:13px;margin:0}.cal-header-right{display:flex;gap:8px;align-items:center}.cal-settings-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--cd-border);color:var(--cd-muted-fg);border-radius:10px;cursor:pointer;transition:all .15s}.cal-settings-btn:hover{border-color:var(--cd-primary);color:var(--cd-primary);background:var(--cd-accent)}.cal-settings-views{display:flex;gap:8px;flex-wrap:wrap}.cal-settings-view-btn{padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--cd-border);background:#f8fafc;color:#475569;transition:all .15s}.dark .cal-settings-view-btn{background:#0a0f1a;color:#94a3b8;border-color:#1e293b99}.cal-settings-view-btn:hover{border-color:var(--cd-primary);color:var(--cd-primary)}.cal-settings-view-btn.active{background:var(--cd-primary);color:var(--cd-primary-fg);border-color:var(--cd-primary)}.cal-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.cal-toolbar-left{display:flex;align-items:center;gap:6px}.cal-toolbar-center{display:flex;align-items:center;gap:16px}.cal-toolbar-right{display:flex;align-items:center;gap:8px}.cal-month-label{font-size:20px;font-weight:800;color:var(--cd-fg);min-width:220px;text-align:center;letter-spacing:-.02em}.cal-arrow{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--cd-border);color:var(--cd-muted-fg);border-radius:10px;cursor:pointer;transition:all .15s}.cal-arrow:hover{border-color:var(--cd-primary);color:var(--cd-primary);background:var(--cd-accent)}.cal-today-btn{padding:7px 16px;font-size:13px;font-weight:600;border-radius:10px;background:none;border:1px solid var(--cd-border);color:var(--cd-fg);cursor:pointer;transition:all .15s}.cal-today-btn:hover{border-color:var(--cd-primary);color:var(--cd-primary)}.cal-view-tabs{display:flex;background:var(--cd-accent);border:1px solid var(--cd-border);border-radius:10px;overflow:hidden}.cal-view-tab{padding:7px 18px;font-size:12px;font-weight:600;color:var(--cd-muted-fg);background:none;border:none;cursor:pointer;transition:all .15s}.cal-view-tab:hover{color:var(--cd-fg)}.cal-view-tab.active{background:var(--cd-primary);color:var(--cd-primary-fg)}.cal-legend{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:18px;padding:0 2px}.cal-legend-item{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--cd-muted-fg);font-weight:500}.cal-legend-dot{width:10px;height:10px;border-radius:3px}.cal-grid{border:1px solid var(--cd-border);border-radius:14px;overflow:hidden;background:#fff}.dark .cal-grid{background:var(--cd-card)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#f8fafc;border-bottom:1px solid var(--cd-border)}.dark .cal-weekdays{background:#ffffff08}.cal-weekday{padding:14px 12px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--cd-muted-fg)}.cal-days{display:grid;grid-template-columns:repeat(7,1fr)}.cal-day{min-height:120px;padding:10px 12px;border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;cursor:pointer;transition:all .15s;position:relative;display:flex;flex-direction:column;background:#fff}.dark .cal-day{border-right-color:#ffffff0f;border-bottom-color:#ffffff0f;background:transparent}.cal-day:nth-child(7n){border-right:none}.cal-day:hover{background:#f1f5f9}.dark .cal-day:hover{background:#22d3ee0a}.cal-day.other-month{opacity:.3}.cal-day.other-month:hover{opacity:.5}.cal-day.selected{background:#ecfeff}.dark .cal-day.selected{background:#22d3ee0f}.cal-page .cal-day-num{font-size:16px!important;font-weight:700!important;color:#2a2e3a!important;width:34px!important;height:34px!important;display:flex;align-items:center;justify-content:center;border-radius:10px!important;margin-bottom:6px;transition:all .15s}.dark .cal-page .cal-day-num{color:#e2e8f0!important}.cal-page .cal-day.today .cal-day-num{background:var(--cd-primary)!important;color:var(--cd-primary-fg)!important;font-weight:800!important;font-size:17px!important}.cal-page .cal-day.selected:not(.today) .cal-day-num{background:#0891b21f!important;color:#0891b2!important;font-weight:800!important}.dark .cal-page .cal-day.selected:not(.today) .cal-day-num{background:#22d3ee26!important;color:#22d3ee!important}.cal-day-events{display:flex;flex-direction:column;gap:3px;flex:1}.cal-day-event{font-size:11px;padding:3px 7px;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;line-height:1.2;border-left:3px solid}.cal-day-event.task{background:#0891b21a;color:#0e7490;border-color:#0891b2}.cal-day-event.followup{background:#f59e0b1a;color:#92400e;border-color:#f59e0b}.cal-day-event.touchpoint{background:#8b5cf61a;color:#6d28d9;border-color:#8b5cf6}.cal-day-event.transaction{background:#16a34a1a;color:#166534;border-color:#16a34a}.dark .cal-day-event.task{background:#22d3ee1a;color:#7dd8e8;border-color:#22d3ee}.dark .cal-day-event.followup{background:#f59e0b1a;color:#f5c363;border-color:#f59e0b}.dark .cal-day-event.touchpoint{background:#a78bfa1a;color:#bba8f7;border-color:#a78bfa}.dark .cal-day-event.transaction{background:#22c55e1a;color:#6dd4a0;border-color:#22c55e}.cal-day-more{font-size:10px;color:var(--cd-muted-fg);padding:2px 7px;font-weight:600}.cal-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}@media(max-width:1100px){.cal-layout{grid-template-columns:1fr}}.cal-detail{background:#fff;border:1px solid var(--cd-border);border-radius:14px;position:sticky;top:16px;overflow:hidden}.dark .cal-detail{background:var(--cd-card)}.cal-detail-header{padding:18px 20px;border-bottom:1px solid var(--cd-border);background:#f8fafc}.dark .cal-detail-header{background:#ffffff08}.cal-detail-header h3{font-size:15px;font-weight:700;margin:0 0 4px;color:var(--cd-fg);display:flex;align-items:center;gap:8px}.cal-detail-date{font-size:12px;color:var(--cd-muted-fg)}.cal-detail-body{padding:16px 20px}.cal-event-count{font-size:12px;color:var(--cd-primary);font-weight:600;margin-bottom:14px}.cal-event-list{display:flex;flex-direction:column;gap:10px}.cal-event-card{padding:12px 14px;border-radius:10px;background:#f8fafc;border:1px solid var(--cd-border);display:flex;gap:12px;transition:border-color .15s;position:relative}.cal-event-card.compact{padding:10px 12px}.dark .cal-event-card{background:var(--cd-bg)}.cal-event-card:hover{border-color:var(--cd-primary)}.cal-event-stripe{width:4px;border-radius:4px;flex-shrink:0;align-self:stretch}.cal-event-stripe.task{background:var(--cd-primary)}.cal-event-stripe.followup{background:#f59e0b}.cal-event-stripe.touchpoint{background:#8b5cf6}.cal-event-stripe.transaction{background:#16a34a}.cal-event-body{flex:1;min-width:0}.cal-event-title{font-size:13px;font-weight:600;color:var(--cd-fg);line-height:1.3}.cal-event-title.completed{text-decoration:line-through;opacity:.45}.cal-event-type{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.cal-event-type.task{color:var(--cd-primary)}.cal-event-type.followup{color:#d97706}.cal-event-type.touchpoint{color:#7c3aed}.cal-event-type.transaction{color:#16a34a}.dark .cal-event-type.followup{color:#f59e0b}.dark .cal-event-type.touchpoint{color:#a78bfa}.dark .cal-event-type.transaction{color:#22c55e}.cal-event-desc{font-size:11px;color:var(--cd-muted-fg);margin-top:4px;line-height:1.4}.cal-event-actions{display:flex;gap:2px;flex-shrink:0;align-self:flex-start}.cal-day-view{max-width:900px}.cal-day-view-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:#fff;border:1px solid var(--cd-border);border-radius:14px;margin-bottom:16px}.dark .cal-day-view-header{background:var(--cd-card)}.cal-day-view-info{display:flex;align-items:center;gap:12px}.cal-day-view-info h3{font-size:18px;font-weight:700;margin:0;color:var(--cd-fg)}.cal-day-view-count{font-size:12px;color:var(--cd-muted-fg);font-weight:500}.cal-day-view-events{background:#fff;border:1px solid var(--cd-border);border-radius:14px;overflow:hidden;margin-bottom:16px}.dark .cal-day-view-events{background:var(--cd-card)}.cal-day-view-events-label{padding:12px 20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--cd-muted-fg);border-bottom:1px solid var(--cd-border);background:#f8fafc}.dark .cal-day-view-events-label{background:#ffffff08}.cal-day-view-events .cal-event-list{padding:14px 18px}.cal-day-view-timeline{background:#fff;border:1px solid var(--cd-border);border-radius:14px;overflow:hidden}.dark .cal-day-view-timeline{background:var(--cd-card)}.cal-day-view-hour{display:flex;align-items:flex-start;min-height:48px;border-bottom:1px solid var(--cd-border);position:relative}.cal-day-view-hour:last-child{border-bottom:none}.cal-day-view-hour.current{background:#0891b20a}.dark .cal-day-view-hour.current{background:#22d3ee0a}.cal-day-view-hour-label{width:72px;padding:8px 14px;font-size:11px;font-weight:600;color:var(--cd-muted-fg);text-align:right;flex-shrink:0}.cal-day-view-hour-line{flex:1;border-left:1px solid var(--cd-border);min-height:48px}.cal-day-view-hour.current .cal-day-view-hour-label{color:var(--cd-primary);font-weight:700}.cal-day-view-hour.current .cal-day-view-hour-line{border-left-color:var(--cd-primary)}.cal-agenda{display:flex;flex-direction:column;gap:16px;max-width:800px}.cal-agenda-group{background:#fff;border:1px solid var(--cd-border);border-radius:14px;overflow:hidden}.dark .cal-agenda-group{background:var(--cd-card)}.cal-agenda-date{padding:12px 18px;background:#f8fafc;border-bottom:1px solid var(--cd-border);display:flex;align-items:center;gap:10px}.dark .cal-agenda-date{background:#ffffff08}.cal-agenda-date-label{font-size:14px;font-weight:700;color:var(--cd-fg)}.cal-agenda-date-sub{font-size:12px;color:var(--cd-muted-fg)}.cal-agenda-today{font-size:10px;padding:2px 10px;background:var(--cd-primary);color:var(--cd-primary-fg);border-radius:20px;font-weight:700}.cal-agenda-count{margin-left:auto;font-size:11px;color:var(--cd-muted-fg)}.cal-agenda-events{padding:10px 14px;display:flex;flex-direction:column;gap:8px}.cal-agenda-event{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;border:1px solid var(--cd-border);background:#f8fafc;transition:border-color .15s}.dark .cal-agenda-event{background:var(--cd-bg)}.cal-agenda-event:hover{border-color:var(--cd-primary)}.cal-timeline{max-width:800px}.cal-timeline-list{position:relative;padding-left:28px}.cal-timeline-list:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:var(--cd-border);border-radius:2px}.cal-timeline-date-header{display:flex;align-items:center;gap:10px;padding:14px 0 8px;position:relative}.cal-timeline-date-header:first-child{padding-top:0}.cal-timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--cd-border);border:2px solid #ffffff;position:absolute;left:-23px;z-index:1}.dark .cal-timeline-dot{border-color:var(--cd-bg)}.cal-timeline-date-header.today .cal-timeline-dot{background:var(--cd-primary)}.cal-timeline-date-text{font-size:14px;font-weight:700;color:var(--cd-fg)}.cal-timeline-item{position:relative;padding:0 0 12px;margin-left:0}.cal-timeline-connector{position:absolute;left:-22px;top:14px;width:14px;height:1px;background:var(--cd-border)}.cal-timeline-card{padding:12px 14px;border-radius:10px;background:#fff;border:1px solid var(--cd-border);display:flex;gap:12px;transition:border-color .15s}.dark .cal-timeline-card{background:var(--cd-card)}.cal-timeline-card:hover{border-color:var(--cd-primary)}.cal-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.cal-btn-primary{background:var(--cd-primary);color:var(--cd-primary-fg);font-weight:700}.cal-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #0891b240}.cal-btn-secondary{background:#fff;color:var(--cd-fg);border:1px solid var(--cd-border)}.dark .cal-btn-secondary{background:var(--cd-card)}.cal-btn-secondary:hover{border-color:var(--cd-primary);color:var(--cd-primary)}.cal-btn-sm{padding:5px 12px;font-size:12px}.cal-btn-full{width:100%;justify-content:center}.cal-overlay{position:fixed;inset:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cal-modal{background:#fff!important;border:1px solid #d1d5db;border-radius:16px;width:100%;max-width:520px;box-shadow:0 24px 80px #0003,0 0 0 1px #0000000d;overflow:hidden}.dark .cal-modal{background:#0b1220!important;border-color:#ffffff14;box-shadow:0 24px 80px #000000b3}.cal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--cd-border)}.cal-modal-header h3{font-size:16px;font-weight:700;margin:0;color:var(--cd-fg);display:flex;align-items:center;gap:8px}.cal-modal-close{background:none;border:none;color:var(--cd-muted-fg);cursor:pointer;padding:6px;border-radius:8px;display:flex;transition:all .15s}.cal-modal-close:hover{color:var(--cd-fg);background:#f1f5f9}.dark .cal-modal-close:hover{background:#ffffff0f}.cal-modal-body{padding:24px}.cal-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--cd-border)}.cal-modal .cal-field{margin-bottom:14px}.cal-modal .cal-field label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--cd-muted-fg);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.cal-modal .cal-field input,.cal-modal .cal-field select,.cal-modal .cal-field textarea{width:100%;padding:11px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;color:#2d3340;font-size:14px;outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s,background .15s;font-family:inherit}.dark .cal-modal .cal-field input,.dark .cal-modal .cal-field select,.dark .cal-modal .cal-field textarea{background:#ffffff08;border-color:#ffffff14;color:#e2e8f0}.dark .cal-modal .cal-field input::placeholder,.dark .cal-modal .cal-field textarea::placeholder{color:#e2e8f059}.cal-modal .cal-field input:hover,.cal-modal .cal-field select:hover,.cal-modal .cal-field textarea:hover{border-color:#22d3ee40}.dark .cal-modal .cal-field input:hover,.dark .cal-modal .cal-field select:hover,.dark .cal-modal .cal-field textarea:hover{border-color:#22d3ee4d;background:#ffffff0b}.cal-modal .cal-field input:focus,.cal-modal .cal-field select:focus,.cal-modal .cal-field textarea:focus{border-color:var(--cd-primary);box-shadow:0 0 0 3px #22d3ee26;background:#fff}.dark .cal-modal .cal-field input:focus,.dark .cal-modal .cal-field select:focus,.dark .cal-modal .cal-field textarea:focus{background:#ffffff0f}.cal-modal .cal-field textarea{resize:vertical;min-height:72px;line-height:1.5}.cal-modal .cal-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}.dark .cal-modal .cal-field input[type=date]::-webkit-calendar-picker-indicator,.dark .cal-modal .cal-field input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.7) sepia(1) saturate(5) hue-rotate(155deg);cursor:pointer;opacity:.85}.cal-modal .cal-field input[type=date],.cal-modal .cal-field input[type=time]{cursor:pointer}.cal-icon-btn{background:none;border:none;color:var(--cd-muted-fg);cursor:pointer;padding:5px;border-radius:7px;display:flex;align-items:center;transition:all .15s}.cal-icon-btn:hover{background:#f1f5f9;color:var(--cd-fg)}.dark .cal-icon-btn:hover{background:#ffffff0f}.cal-icon-btn.danger:hover{color:#ef4444;background:#ef44441a}.cal-empty{text-align:center;padding:40px 20px;color:var(--cd-muted-fg)}.cal-empty svg{margin-bottom:12px;opacity:.2}.cal-empty h3{color:var(--cd-fg);font-size:15px;margin:0 0 6px}.cal-empty p{font-size:13px;margin:0 0 16px}.cal-spinner-wrap{display:flex;align-items:center;justify-content:center;padding:80px}.cal-spinner{width:32px;height:32px;border:2.5px solid var(--cd-border);border-top-color:var(--cd-primary);border-radius:50%;animation:spin .8s linear infinite}.cal-toast{position:fixed;bottom:24px;right:24px;background:#fff;color:var(--cd-fg);padding:12px 20px;border-radius:12px;font-size:13px;z-index:9999;box-shadow:0 8px 30px #0000001f;border-left:3px solid var(--cd-primary);animation:calSlideUp .3s ease;border:1px solid var(--cd-border)}.dark .cal-toast{background:#1e293b;box-shadow:0 8px 30px #0006}@keyframes calSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cal-priority{font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}.cal-priority.high{background:#ef44441f;color:#dc2626}.cal-priority.medium{background:#f59e0b1f;color:#d97706}.cal-priority.low{background:#6b72801f;color:#6b7280}.dark .cal-priority.high{background:#ef444426;color:#ef4444}.dark .cal-priority.medium{background:#f59e0b26;color:#f59e0b}.dark .cal-priority.low{background:#6b728026;color:#9ca3af}@media(max-width:768px){.cal-page{padding:16px}.cal-toolbar{flex-direction:column;align-items:stretch}.cal-toolbar-center,.cal-toolbar-right{justify-content:center}.cal-month-label{font-size:17px;min-width:auto}.cal-day{min-height:80px;padding:6px}.cal-day-num{font-size:13px;width:28px;height:28px}.cal-day-event{display:none}.cal-day-dots{display:flex!important}.cal-weekday{padding:10px 4px;font-size:10px;text-align:center}.cal-view-tabs{flex-wrap:wrap}.cal-view-tab{padding:6px 12px;font-size:11px}.cal-day-view-header{flex-direction:column;gap:10px;align-items:flex-start}.cal-day-view-info{flex-wrap:wrap}}.cal-day-dots{display:none;gap:3px;flex-wrap:wrap;margin-top:auto}.cal-day-dot-sm{width:6px;height:6px;border-radius:50%}.cal-day-event.appointment{background:#ec48991a;color:#be185d;border-color:#ec4899}.dark .cal-day-event.appointment{background:#ec48991a;color:#f472b6;border-color:#ec4899}.cal-event-stripe.appointment{background:#ec4899}.cal-event-type.appointment{color:#ec4899}.dark .cal-event-type.appointment{color:#f472b6}
