.cal{margin-top:.25rem}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.cal-header-left{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.cal-title{font-size:1.5rem;font-weight:600;letter-spacing:-.01em;margin:0 .5rem;color:var(--text-primary);min-width:11rem;text-align:center}.cal-title--clickable{background:none;border:none;padding:.25rem .5rem;border-radius:6px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;transition:background-color .1s ease}.cal-title--clickable:hover{background:var(--bg-secondary)}.cal-title--clickable:focus-visible{outline:2px solid color-mix(in srgb,var(--primary-color) 50%,transparent);outline-offset:2px}.cal-title-caret{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.cal-month-picker-hidden{position:absolute;width:1px;height:1px;padding:0;border:0;margin:0;overflow:hidden;clip:rect(0 0 0 0);pointer-events:none}.cal-nav-btn{width:32px;height:32px;border-radius:6px;border:1px solid var(--border-color);background:var(--surface-color);color:var(--text-primary);font-size:1.125rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .1s}.cal-nav-btn:hover{background:var(--bg-secondary)}.cal-month-picker{margin-left:.5rem;height:32px;padding:0 .5rem;border-radius:6px;border:1px solid var(--border-color);background:var(--surface-color);color:var(--text-primary);font-size:.875rem}.cal-today-btn{height:32px;padding:0 .75rem;border-radius:6px;border:1px solid var(--border-color);background:var(--surface-color);color:var(--text-primary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .1s}.cal-today-btn:hover{background:var(--bg-secondary)}.cal-header-right{display:flex;align-items:center;gap:.875rem;line-height:1.2}.cal-month-stat{display:flex;flex-direction:column;align-items:flex-end}.cal-month-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);white-space:nowrap}.cal-month-stat-value{font-size:1.5rem;font-weight:600;color:var(--primary-color);font-variant-numeric:tabular-nums}.cal-month-stat-value--low{color:var(--danger-color)}.cal-month-stat-value--muted{color:var(--text-secondary)}.cal-month-stat-divider{width:1px;height:28px;background:var(--border-color)}.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr)) 88px;background:var(--border-color);gap:1px;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.cal-weekday{background:var(--bg-secondary);padding:.5rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.cal-weekday--total{text-align:center;padding:.5rem}.cal-day{background:var(--surface-color);min-height:124px;padding:.5rem .625rem 1.875rem;position:relative;cursor:pointer;transition:background-color .12s ease;display:flex;flex-direction:column}.cal-day:hover{background:color-mix(in srgb,var(--primary-color) 4%,var(--surface-color))}.cal-day--outside{opacity:.45}.cal-day--weekend{background:var(--bg-secondary)}.cal-day--weekend:hover{background:color-mix(in srgb,var(--primary-color) 4%,var(--bg-secondary))}.cal-day--under{background:color-mix(in srgb,var(--danger-color) 7%,var(--surface-color))}.cal-day--under:hover{background:color-mix(in srgb,var(--danger-color) 10%,var(--surface-color))}.cal-day--empty{background:color-mix(in srgb,var(--danger-color) 4%,var(--surface-color))}.cal-day--empty:hover{background:color-mix(in srgb,var(--danger-color) 8%,var(--surface-color))}.cal-day--timeoff{border-left:3px dotted var(--primary-color);padding-left:calc(.625rem - 3px)}.cal-day--today{box-shadow:inset 0 0 0 2px var(--primary-color)}.cal-day-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.375rem}.cal-day-num{font-size:.875rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.cal-day--today .cal-day-num{color:var(--primary-color)}.cal-day-total{font-size:.75rem;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums;background:var(--bg-secondary);padding:.0625rem .4375rem;border-radius:999px;border:1px solid var(--border-color)}.cal-day--under .cal-day-total{color:var(--danger-color);background:color-mix(in srgb,var(--danger-color) 14%,transparent);border-color:color-mix(in srgb,var(--danger-color) 30%,transparent)}.cal-day--full .cal-day-total{color:var(--success-color);background:color-mix(in srgb,var(--success-color) 14%,transparent);border-color:color-mix(in srgb,var(--success-color) 30%,transparent)}.cal-day-entries{display:flex;flex-direction:column;gap:.1875rem;flex:1;min-width:0}.cal-chip{display:flex;align-items:center;gap:.375rem;padding:.1875rem .4375rem;background:color-mix(in srgb,var(--primary-color) 9%,transparent);border:1px solid color-mix(in srgb,var(--primary-color) 22%,transparent);border-radius:4px;font-size:.7rem;color:var(--text-primary);cursor:pointer;text-align:left;width:100%;overflow:hidden;white-space:nowrap;font-family:inherit;transition:background-color .1s}.cal-chip:hover{background:color-mix(in srgb,var(--primary-color) 18%,transparent)}.cal-chip-hours{font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0;color:var(--primary-color)}.cal-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cal-chip--timeoff{background:color-mix(in srgb,var(--success-color) 12%,transparent);border-color:color-mix(in srgb,var(--success-color) 28%,transparent);border-style:dashed}.cal-chip--timeoff:hover{background:color-mix(in srgb,var(--success-color) 22%,transparent)}.cal-chip--timeoff .cal-chip-hours{color:var(--success-color)}.cal-more{font-size:.7rem;color:var(--text-secondary);padding:.1875rem .4375rem;font-style:italic;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;border-radius:4px;transition:background-color .1s;align-self:flex-start}.cal-more:hover{background:color-mix(in srgb,var(--primary-color) 10%,transparent);color:var(--primary-color)}.cal-more--collapse{font-style:normal;font-weight:600;color:var(--primary-color)}.cal-day-add{position:absolute;bottom:.4375rem;right:.4375rem;height:22px;padding:0 .5rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--primary-color) 35%,transparent);background:var(--surface-color);color:var(--primary-color);font-size:.7rem;font-weight:600;cursor:pointer;opacity:0;transition:opacity 80ms ease,background-color .1s;font-family:inherit}.cal-day:hover .cal-day-add{opacity:1}.cal-day-add:hover{background:color-mix(in srgb,var(--primary-color) 12%,var(--surface-color))}.cal-week-total{background:var(--bg-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .375rem;gap:.125rem}.cal-week-total-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.cal-week-total-value{font-size:1rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.cal-week-total--low .cal-week-total-value{color:var(--danger-color)}.cal-legend{display:flex;gap:1.25rem;margin-top:.875rem;flex-wrap:wrap;font-size:.75rem;color:var(--text-secondary)}.cal-legend-item{display:inline-flex;align-items:center;gap:.5rem}.cal-legend-dot{width:14px;height:14px;border-radius:3px;display:inline-block}.cal-legend-dot--under{background:color-mix(in srgb,var(--danger-color) 18%,var(--surface-color));border:1px solid color-mix(in srgb,var(--danger-color) 40%,transparent)}.cal-legend-dot--weekend{background:var(--bg-secondary);border:1px solid var(--border-color)}.cal-legend-dot--timeoff{background:var(--surface-color);border:1px solid var(--border-color);border-left:3px dotted var(--primary-color)}.cal-legend-dot--today{background:var(--surface-color);box-shadow:inset 0 0 0 2px var(--primary-color);border:1px solid var(--border-color)}@media (max-width: 900px){.cal-grid{grid-template-columns:repeat(7,minmax(0,1fr)) 60px}.cal-day{min-height:96px;padding:.375rem .4375rem 1.625rem}.cal-chip{padding:.125rem .3125rem}.cal-week-total-value{font-size:.875rem}}.calendar-hub-page{padding:24px;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.header-content h1{margin:0;font-size:28px;font-weight:600;color:var(--text-primary)}.header-subtitle{margin:4px 0 0;color:var(--text-secondary);font-size:14px}.header-actions{display:flex;gap:12px}.header-actions .icon{margin-right:6px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.error-message{color:var(--danger-color);margin-bottom:16px}.dashboard-top-section{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.booking-url-card{display:flex;flex-direction:column}.booking-url-description{margin:0 0 16px;color:var(--text-secondary);font-size:14px}.booking-url-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;margin-bottom:16px}.booking-url-box code{font-family:Monaco,Consolas,monospace;font-size:13px;color:var(--text-primary);word-break:break-all}.booking-url-actions{display:flex;gap:12px}.availability-card{display:flex;flex-direction:column}.availability-overview{display:flex;flex-direction:column;gap:8px}.availability-day{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;font-size:14px}.availability-day.unavailable{opacity:.5}.day-abbr{font-weight:600;color:var(--text-primary);min-width:40px}.day-hours{color:var(--text-secondary);font-family:Monaco,Consolas,monospace;font-size:13px}.day-off{color:var(--text-secondary)}.no-availability{color:var(--text-secondary);text-align:center;padding:20px;margin:0}.setup-notice-card{margin-bottom:24px;border:2px dashed var(--border-color);background:var(--bg-secondary)}.setup-notice-content{display:flex;align-items:center;gap:20px;padding:24px}.setup-icon{font-size:48px;flex-shrink:0}.setup-text{flex:1}.setup-text h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.setup-text p{margin:0;color:var(--text-secondary);font-size:14px}.calendar-hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:24px}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.card-title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.card-content{padding:20px}.calendar-connections{display:flex;flex-direction:column;gap:16px}.connection-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--bg-secondary);border-radius:8px}.connection-provider{display:flex;align-items:center;gap:12px}.provider-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);flex-shrink:0}.provider-info h4{margin:0 0 2px;font-size:14px;font-weight:600;color:var(--text-primary)}.provider-info .connected-email{margin:0;font-size:13px;color:var(--success-color)}.provider-info .not-connected{margin:0;font-size:13px;color:var(--text-secondary)}.connection-hint{margin:16px 0 0;padding:12px;background:var(--bg-tertiary);border-radius:6px;font-size:13px;color:var(--text-secondary);text-align:center}.primary-badge{margin-left:8px;padding:2px 6px;font-size:10px;font-weight:600;background:var(--primary-color);color:#fff;border-radius:4px;text-transform:uppercase;vertical-align:middle}.empty-calendars-state{text-align:center;padding:20px}.empty-calendars-state p{margin:0 0 8px;color:var(--text-secondary)}.connect-buttons{display:flex;justify-content:center;gap:12px;margin-top:16px;flex-wrap:wrap}.connect-buttons .btn{gap:8px}.meeting-types-list{display:flex;flex-direction:column;gap:12px}.meeting-type-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px}.meeting-type-color{width:12px;height:40px;border-radius:4px;flex-shrink:0}.meeting-type-info{flex:1}.meeting-type-info h4{margin:0 0 2px;font-size:14px;font-weight:600;color:var(--text-primary)}.meeting-type-info p{margin:0;font-size:13px;color:var(--text-secondary)}.bookings-card{width:100%}.bookings-table-container{overflow-x:auto}.bookings-table{width:100%;border-collapse:collapse}.bookings-table th,.bookings-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.bookings-table th{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-secondary)}.bookings-table tbody tr:hover{background:var(--bg-secondary)}.booking-datetime{font-weight:500;color:var(--text-primary);white-space:nowrap}.meeting-type-cell{display:flex;align-items:center;gap:8px}.meeting-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.guest-info{display:flex;flex-direction:column}.guest-name{font-weight:500;color:var(--text-primary)}.guest-email{font-size:12px;color:var(--text-secondary)}.empty-state{text-align:center;padding:20px;color:var(--text-secondary)}.empty-state p{margin:0 0 12px}.empty-hint{font-size:13px}.empty-hint a{color:var(--primary-color)}.badge{display:inline-block;padding:4px 8px;font-size:12px;font-weight:500;border-radius:4px;text-transform:capitalize}.badge-danger{background:var(--danger-bg);color:var(--danger-color)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .2s;text-decoration:none}.btn-sm{padding:4px 10px;font-size:12px}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary)}.btn-outline.btn-danger{color:var(--danger-color);border-color:var(--danger-color)}.btn-outline.btn-danger:hover{background:var(--danger-bg)}.group-bookings-header{display:flex;justify-content:flex-end;margin-bottom:20px}.group-section{margin-bottom:32px}.group-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.group-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.group-card .card-header{padding:14px 20px}.group-card-title-row{display:flex;align-items:center;gap:12px;width:100%}.group-description{margin:0 0 12px;font-size:13px;color:var(--text-secondary)}.group-members-display{display:flex;gap:8px;margin-bottom:8px;font-size:13px}.group-label{font-weight:600;color:var(--text-secondary);white-space:nowrap}.group-value{color:var(--text-primary)}.group-warning{padding:6px 10px;margin-bottom:8px;background:var(--warning-bg, #fef3c7);color:var(--warning-color, #92400e);border-radius:6px;font-size:12px}.group-booking-url{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;margin:12px 0}.group-booking-url code{flex:1;font-size:12px;color:var(--text-primary);word-break:break-all;font-family:Monaco,Consolas,monospace}.group-card-actions{display:flex;gap:8px;margin-top:12px}.modal-group{max-width:860px;display:flex;flex-direction:column;overflow-y:hidden}.modal-group .modal-body{flex:1;min-height:0;max-height:calc(90vh - 140px);overflow-y:auto}.modal-group .modal-header,.modal-group .modal-footer{flex-shrink:0}.modal-group .form-group{margin-bottom:16px}.modal-group .form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.modal-group .form-group input[type=text],.modal-group .form-group input[type=number],.modal-group .form-group textarea,.modal-group .form-group select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;color:var(--text-primary);background:var(--bg-primary);box-sizing:border-box}.modal-group .form-group textarea{resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-hint{margin:0 0 8px;font-size:12px;color:var(--text-secondary)}.slug-input-group{display:flex;align-items:center;border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.slug-prefix{padding:8px 4px 8px 12px;font-size:13px;color:var(--text-secondary);background:var(--bg-secondary);white-space:nowrap;font-family:Monaco,Consolas,monospace}.slug-input-group input{border:none!important;border-radius:0!important;font-family:Monaco,Consolas,monospace;font-size:13px}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto!important}.meeting-types-editor{display:flex;flex-direction:column;gap:8px}.mt-editor-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.mt-color-wrapper{position:relative;flex-shrink:0}.mt-color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s;padding:0}.mt-color-swatch:hover{transform:scale(1.1)}.mt-color-dropdown{position:absolute;top:36px;left:50%;transform:translate(-50%);display:flex;gap:6px;flex-wrap:wrap;width:152px;padding:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10}.mt-color-option{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .15s}.mt-color-option:hover{transform:scale(1.15)}.mt-color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.mt-name-input{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;color:var(--text-primary);background:var(--bg-primary)}.mt-duration-input{display:flex;align-items:center;gap:4px;flex-shrink:0}.mt-duration-input input{width:56px;padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;color:var(--text-primary);background:var(--bg-primary);text-align:center}.mt-duration-label{font-size:12px;color:var(--text-secondary)}.mt-remove-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:18px;cursor:pointer;flex-shrink:0;line-height:1}.mt-remove-btn:hover{background:var(--danger-bg);color:var(--danger-color)}.mt-add-btn{align-self:flex-start;margin-top:4px}.member-filter-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:13px;color:var(--text-primary);background:var(--bg-primary);margin-bottom:8px;box-sizing:border-box}.member-selection-list{max-height:240px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px}.member-selection-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .15s}.member-selection-item:last-child{border-bottom:none}.member-selection-item:hover{background:var(--bg-secondary)}.member-selection-item input[type=checkbox]{flex-shrink:0}.member-selection-info{display:flex;flex-direction:column;flex:1;min-width:0}.member-name{font-size:14px;font-weight:500;color:var(--text-primary)}.member-email{font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.calendar-hub-page{padding:16px}.page-header{flex-direction:column;gap:12px}.calendar-hub-grid,.dashboard-top-section{grid-template-columns:1fr}.booking-url-actions{flex-direction:column}.booking-url-actions .btn{width:100%;justify-content:center}.setup-notice-content{flex-direction:column;text-align:center}.bookings-table th,.bookings-table td{padding:8px 12px;font-size:13px}.group-cards-grid,.form-row{grid-template-columns:1fr}}.calendar-settings-page{padding:24px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:24px}.back-link{display:inline-block;color:var(--text-secondary);text-decoration:none;font-size:14px;margin-bottom:8px}.back-link:hover{color:var(--primary-color)}.page-header h1{margin:0;font-size:28px;font-weight:600;color:var(--text-primary)}.calendar-settings-page .alert{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.calendar-settings-page .alert button{background:none;border:none;font-size:20px;cursor:pointer;opacity:.7}.calendar-settings-page .alert button:hover{opacity:1}.calendar-settings-page .alert-error{background:var(--danger-bg);color:var(--danger-color)}.calendar-settings-page .alert-success{background:var(--success-bg);color:var(--success-color)}.settings-layout{display:flex;gap:24px}.settings-nav{width:220px;flex-shrink:0}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);text-align:left;transition:all .2s}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item.active{background:var(--primary-color);color:#fff}.nav-icon{font-size:16px}.settings-content{flex:1;min-width:0}.settings-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:24px}.settings-section h2{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--text-primary)}.section-description{margin:0 0 24px;color:var(--text-secondary);font-size:14px}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.form-group{margin-bottom:24px}.form-group label{display:block;font-weight:500;margin-bottom:6px;color:var(--text-primary);font-size:14px}.form-group input[type=text],.form-group input[type=time],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-group input.error{border-color:var(--danger-color)}.form-group input.success{border-color:var(--success-color)}.form-hint{margin:6px 0 0;font-size:12px;color:var(--text-secondary)}.form-actions{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.toggle-label{display:inline-flex!important;align-items:center;gap:12px;cursor:pointer;margin-bottom:0}.toggle-label.compact{gap:8px}.toggle-label input[type=checkbox]{display:none}.toggle-slider{position:relative;width:44px;height:24px;background:var(--border-color);border-radius:12px;transition:background .3s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .3s}.toggle-label input:checked+.toggle-slider{background:var(--primary-color)}.toggle-label input:checked+.toggle-slider:after{transform:translate(20px)}.toggle-text{font-weight:500;color:var(--text-primary)}.slug-input-group{display:flex;align-items:center;background:var(--bg-secondary);border-radius:6px}.slug-prefix{padding:10px 12px;font-size:13px;color:var(--text-secondary);white-space:nowrap;background:var(--bg-secondary);border:1px solid var(--border-color);border-right:none;border-radius:6px 0 0 6px}.slug-input-group input[type=text]{flex:1;min-width:0;padding:10px 12px;border:1px solid var(--border-color);border-radius:0 6px 6px 0;margin:0;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.slug-status{padding:8px 12px;font-size:12px;white-space:nowrap}.slug-status.checking{color:var(--text-secondary)}.slug-status.available{color:var(--success-color)}.slug-status.taken{color:var(--danger-color)}.calendar-connections-settings{display:flex;flex-direction:column;gap:12px}.connection-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-radius:8px}.connection-info{display:flex;align-items:center;gap:12px}.connection-info>div{display:flex;flex-direction:column}.connection-info strong{font-size:14px;color:var(--text-primary)}.connection-info .connected-email,.connection-info .not-connected{font-size:12px}.connection-info .connected-email{color:var(--success-color)}.connection-info .not-connected{color:var(--text-secondary)}.connection-actions{display:flex;align-items:center;gap:16px}.radio-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);cursor:pointer}.radio-label input{accent-color:var(--primary-color)}.provider-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);flex-shrink:0}.provider-icon svg{display:block}.availability-grid{display:flex;flex-direction:column;gap:12px}.availability-row{display:flex;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-radius:8px;gap:16px}.availability-row.disabled{opacity:.6}.day-toggle{display:flex;align-items:center;gap:12px;min-width:160px}.day-name{font-weight:500;color:var(--text-primary)}.time-range{display:flex;align-items:center;gap:10px}.time-range input[type=time]{width:120px;padding:8px 10px}.time-separator{color:var(--text-secondary);font-size:13px}.unavailable-label{color:var(--text-secondary);font-size:13px;font-style:italic}.meeting-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.meeting-type-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.meeting-type-card.inactive{opacity:.6}.type-color-bar{height:4px}.type-content{padding:16px}.type-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.type-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.type-duration{margin:0 0 8px;color:var(--text-secondary);font-size:13px}.type-description{margin:0 0 12px;color:var(--text-secondary);font-size:13px;line-height:1.5}.type-actions{display:flex;gap:8px}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-option{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-primary);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:18px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;font-size:14px;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .2s;text-decoration:none}.btn-sm{padding:6px 12px;font-size:13px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.btn-outline:hover{background:var(--bg-secondary)}.btn.btn-outline.btn-danger{background:transparent;color:var(--danger-color);border:1px solid var(--danger-color)}.btn.btn-outline.btn-danger:hover{background:var(--danger-bg);color:var(--danger-color)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-state p{margin:0 0 16px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.badge{display:inline-block;padding:3px 8px;font-size:11px;font-weight:500;border-radius:4px;text-transform:capitalize}.badge-success{background:var(--success-bg);color:var(--success-color)}.badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.section-header-inline{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-header-inline label{margin-bottom:0}.empty-calendars{display:flex;flex-direction:column;align-items:center;padding:32px 20px;background:var(--bg-secondary);border-radius:8px;text-align:center}.empty-calendars p{margin:0 0 16px;color:var(--text-secondary)}.modal-connect-calendar{max-width:420px}.connect-wizard-intro{margin:0 0 20px;color:var(--text-secondary);font-size:14px;line-height:1.5}.connect-options{display:flex;flex-direction:column;gap:12px}.connect-option-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.connect-option-card:hover{border-color:var(--primary-color);background:var(--bg-primary);box-shadow:0 2px 8px #00000014}.provider-icon.large{width:48px;height:48px;border-radius:10px}.option-content{flex:1;display:flex;flex-direction:column;gap:4px}.option-content strong{font-size:15px;color:var(--text-primary)}.option-content span{font-size:13px;color:var(--text-secondary)}.option-arrow{font-size:18px;color:var(--text-secondary);transition:transform .2s}.connect-option-card:hover .option-arrow{transform:translate(4px);color:var(--primary-color)}@media (max-width: 768px){.calendar-settings-page{padding:16px}.settings-layout{flex-direction:column}.settings-nav{width:100%;display:flex;overflow-x:auto;gap:8px;padding-bottom:8px}.nav-item{flex-shrink:0;padding:10px 16px}.settings-section{padding:16px}.slug-input-group{flex-direction:column;align-items:stretch}.slug-prefix{border-bottom:1px solid var(--border-color)}.slug-input-group input{border-radius:0 0 6px 6px;border-top:none}.connection-row{flex-direction:column;align-items:flex-start;gap:12px}.connection-actions{width:100%;justify-content:space-between}.availability-row{flex-direction:column;align-items:flex-start;gap:12px}.day-toggle{min-width:auto}.meeting-types-grid{grid-template-columns:1fr}}.public-booking-page{min-height:100vh;height:100vh;overflow-y:auto;background:linear-gradient(135deg,#f5f7fa,#e4e9f2);padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.booking-container{width:100%;max-width:560px;background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;overflow:hidden}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;text-align:center}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.spinner-small{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:48px;margin-bottom:16px}.error-state h2{margin:0 0 8px;color:#1f2937}.error-state p{margin:0;color:#6b7280}.booking-header{padding:32px 32px 24px;text-align:center;border-bottom:1px solid #e5e7eb}.booking-header .looming-logo{height:80px;width:auto;margin-bottom:12px}.host-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:16px;border:3px solid #e5e7eb}.booking-header h1{margin:0 0 8px;font-size:24px;font-weight:600;color:#1f2937}.welcome-message{margin:0;color:#6b7280;font-size:14px;line-height:1.5}.booking-step{padding:24px 32px}.booking-step h2{margin:0 0 20px;font-size:18px;font-weight:600;color:#1f2937}.back-button{display:inline-flex;align-items:center;padding:8px 0;margin-bottom:16px;background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;transition:color .2s}.back-button:hover{color:#3b82f6}.meeting-types{display:flex;flex-direction:column;gap:12px}.meeting-type-option{display:grid;grid-template-columns:4px 1fr auto;gap:16px;align-items:center;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;text-align:left;transition:all .2s}.meeting-type-option:hover{border-color:#3b82f6;background:#f0f7ff}.meeting-type-option .type-color{width:4px;height:100%;min-height:40px;border-radius:2px}.meeting-type-option .type-info{display:flex;flex-direction:column;gap:4px}.meeting-type-option h3{margin:0;font-size:16px;font-weight:600;color:#1f2937}.meeting-type-option .type-duration{font-size:13px;color:#6b7280}.meeting-type-option .type-description{grid-column:2;margin:0;font-size:13px;color:#6b7280;line-height:1.4}.meeting-type-option .arrow{font-size:18px;color:#9ca3af;transition:transform .2s}.meeting-type-option:hover .arrow{transform:translate(4px);color:#3b82f6}.selected-type-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:#f3f4f6;border-radius:20px;font-size:13px;color:#374151;margin-bottom:16px}.type-color-dot{width:10px;height:10px;border-radius:50%}.selected-type-description{margin:0 0 20px;font-size:14px;line-height:1.5;color:#4b5563;max-width:640px}.datetime-picker{display:flex;flex-direction:column;gap:24px}.date-picker label,.time-slots label{display:block;font-size:13px;font-weight:500;color:#6b7280;margin-bottom:8px}.date-picker input[type=date]{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:16px;color:#1f2937}.date-picker input[type=date]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.date-display{margin:8px 0 0;font-size:14px;color:#374151;font-weight:500}.slots-loading{display:flex;align-items:center;gap:12px;padding:20px;color:#6b7280;font-size:14px}.no-slots{padding:24px;text-align:center;background:#f9fafb;border-radius:8px}.no-slots p{margin:0;color:#6b7280}.no-slots .hint{margin-top:4px;font-size:13px;color:#9ca3af}.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.slot-button{padding:12px 8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.slot-button:hover{border-color:#3b82f6;background:#f0f7ff}.slot-button.selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.booking-summary{background:#f9fafb;border-radius:12px;padding:16px;margin-bottom:24px}.summary-item{display:flex;justify-content:space-between;padding:8px 0}.summary-item:not(:last-child){border-bottom:1px solid #e5e7eb}.summary-label{font-size:13px;color:#6b7280}.summary-value{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#1f2937}.booking-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group input,.form-group textarea{padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:16px;color:#1f2937;background:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.submit-button{padding:14px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.submit-button:hover:not(:disabled){background:#2563eb}.submit-button:disabled{opacity:.5;cursor:not-allowed}.confirmation-step{text-align:center;padding:48px 32px}.confirmation-icon{width:64px;height:64px;background:#10b981;color:#fff;font-size:32px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.confirmation-step h2{text-align:center}.confirmation-message{color:#6b7280;margin:0 0 24px;font-size:14px}.confirmation-details{background:#f9fafb;border-radius:12px;padding:20px;margin-bottom:24px;text-align:left}.detail-row{display:flex;justify-content:space-between;padding:10px 0}.detail-row:not(:last-child){border-bottom:1px solid #e5e7eb}.detail-label{font-size:13px;color:#6b7280}.detail-value{font-size:14px;font-weight:500;color:#1f2937;text-align:right}.secondary-button{padding:12px 24px;background:#fff;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.secondary-button:hover{background:#f9fafb;border-color:#d1d5db}.booking-footer{padding:20px;display:flex;align-items:center;justify-content:center;gap:6px;border-top:1px solid #e5e7eb;background:#f9fafb}.booking-footer span{font-size:12px;color:#9ca3af}@media (max-width: 600px){.public-booking-page{padding:0}.booking-container{max-width:100%;min-height:100vh;border-radius:0}.booking-header,.booking-step{padding:24px 20px}.slots-grid{grid-template-columns:repeat(2,1fr)}.detail-row{flex-direction:column;gap:4px}.detail-value{text-align:left}}.group-members-list{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px}.group-member-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#f3f4f6;border-radius:20px;font-size:13px;color:#374151}.group-booking-header-subtitle{margin:4px 0 0;color:#6b7280;font-size:14px}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color: #005493;--primary-hover: #003d6b;--secondary-color: #64748b;--success-color: #22c55e;--danger-color: #ef4444;--warning-color: #f59e0b;--background-color: #f8fafc;--surface-color: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--radius: 8px;--bg-primary: var(--surface-color);--bg-secondary: var(--background-color);--color-error: var(--danger-color);--link-color: #005493;--link-hover: #003d6b}[data-theme=dark]{--primary-color: #0097A7;--primary-hover: #007885;--secondary-color: #94a3b8;--success-color: #4ade80;--danger-color: #f87171;--warning-color: #fbbf24;--background-color: #0f172a;--surface-color: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155;--shadow: 0 1px 3px 0 rgb(0 0 0 / .3), 0 1px 2px -1px rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .3), 0 2px 4px -2px rgb(0 0 0 / .3);--bg-primary: var(--surface-color);--bg-secondary: var(--background-color);--color-error: var(--danger-color);--link-color: #0097A7;--link-hover: #00bcd4;color-scheme:dark}a{color:var(--link-color, var(--primary-color));text-decoration:none}a:hover{color:var(--link-hover, var(--primary-hover));text-decoration:underline}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--background-color);color:var(--text-primary);line-height:1.5}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.layout{display:flex;flex:1;min-height:0}.sidebar{width:250px;background-color:var(--surface-color);border-right:1px solid var(--border-color);padding:1rem 0;display:flex;flex-direction:column;transition:width .2s ease}.sidebar.collapsed{width:50px}.sidebar-header{padding:0 1.5rem 1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between}.sidebar.collapsed .sidebar-header{padding:0 .5rem 1rem;justify-content:center}.sidebar-header h1{font-size:1.25rem;font-weight:600;color:var(--primary-color)}.sidebar-toggle{background:none;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;padding:.25rem .5rem;font-size:1rem;color:var(--text-secondary);transition:all .2s}.sidebar-toggle:hover{background-color:var(--background-color);color:var(--text-primary)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:all .2s;white-space:nowrap;overflow:hidden}.nav-icon{font-size:1.1rem;flex-shrink:0;width:1.5rem;text-align:center}.nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-item{padding:.75rem;justify-content:center}.sidebar.collapsed .nav-label{display:none}.nav-item:hover{background-color:var(--background-color);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-color);color:#fff}.nav-item-nested{padding-left:2.25rem!important}.sidebar.collapsed .nav-item-nested{padding-left:.75rem!important}.menu-group{margin:.25rem .5rem}.menu-group-header{display:flex;align-items:center;width:100%;padding:.625rem .75rem;background-color:#e8f0f8;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.8125rem;font-weight:500;text-align:left}[data-theme=dark] .menu-group-header{background-color:#0a3a5c}.menu-group-header:hover{background-color:var(--background-color);color:var(--text-primary)}.menu-group-header.has-active{color:var(--primary-color)}.menu-group-icon{display:flex;align-items:center;margin-right:.75rem}.menu-group-icon .nav-icon{width:18px;height:18px}.menu-group-title{flex:1}.menu-group-chevron{width:16px;height:16px;transition:transform .2s}.menu-group-chevron.open{transform:rotate(180deg)}.menu-group-items{display:none;flex-direction:column}.menu-group-items.open{display:flex}.main-content{flex:1;padding:2rem;overflow:auto;min-height:0}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:var(--surface-color);border-bottom:1px solid var(--border-color)}.header-user{display:flex;align-items:center;gap:1rem}.theme-toggle-header{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s}.theme-toggle-header:hover{background-color:var(--background-color);color:var(--text-primary)}.theme-toggle-header svg{width:20px;height:20px}.header-user-info{text-align:right}.header-user-name{font-weight:500}.header-user-role{font-size:.875rem;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);color:#fff}a.btn-primary,a.btn-primary:hover{color:#fff;text-decoration:none}.btn-secondary{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-link{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:0;font-size:inherit}.btn-link:hover{text-decoration:underline}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline.btn-danger{background-color:transparent;color:var(--danger-color);border:1px solid var(--danger-color)}.btn-outline.btn-danger:hover:not(:disabled){background-color:var(--danger-bg, rgba(239, 68, 68, .1));color:var(--danger-color)}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-primary)}[data-theme=dark] .form-label,[data-theme=dark] label.form-label{color:var(--text-primary)!important}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--surface-color);color:var(--text-primary);transition:border-color .2s}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea,[data-theme=dark] input.form-input,[data-theme=dark] select.form-select,[data-theme=dark] textarea.form-textarea{color-scheme:dark;background:var(--surface-color)!important;background-color:var(--surface-color)!important;color:var(--text-primary)!important;border-color:var(--border-color)!important}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{min-height:100px;resize:vertical}[data-theme=dark] .form-input[type=date],[data-theme=dark] .form-input[type=time],[data-theme=dark] .form-input[type=datetime-local],[data-theme=dark] .form-input[type=number],[data-theme=dark] input[type=date],[data-theme=dark] input[type=time],[data-theme=dark] input[type=datetime-local]{color-scheme:dark!important}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=datetime-local]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=month]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=week]::-webkit-calendar-picker-indicator{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20a2 2 0 002 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11zM9 11H7v2h2v-2zm4 0h-2v2h2v-2zm4 0h-2v2h2v-2z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:16px;height:16px;opacity:1;cursor:pointer}[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:16px;height:16px;opacity:1;cursor:pointer}.form-error{color:var(--danger-color);font-size:.75rem;margin-top:.25rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.card{background-color:var(--surface-color);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.card-title{font-size:1.125rem;font-weight:600}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.table th{font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);background-color:var(--background-color)}.table tr:hover{background-color:var(--background-color)}.badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.alert{padding:1rem;border-radius:var(--radius);margin-bottom:1rem}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert-info{background-color:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}[data-theme=dark] .alert-info{background-color:#1e3a5f;color:#93c5fd;border:1px solid #2563eb}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background-color:var(--surface-color);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:1.5rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;color:var(--text-primary)}[data-theme=dark] .modal{color:var(--text-primary)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-title{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary)}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--background-color)}.login-card{width:100%;max-width:400px;padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;font-weight:600;color:var(--primary-color)}.login-header p{color:var(--text-secondary);margin-top:.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-title{font-size:1.5rem;font-weight:600}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filters .form-group{margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background-color:var(--surface-color);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.stat-value{font-size:1.5rem;font-weight:600;margin-top:.25rem}.actions{display:flex;gap:.5rem}.tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}.tab{padding:.75rem 1rem;cursor:pointer;border:none;background:none;font-size:.875rem;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.toggle-group{display:flex;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden}.toggle-btn{padding:.5rem 1rem;border:none;background-color:var(--surface-color);color:var(--text-primary);cursor:pointer;font-size:.875rem}.toggle-btn:not(:last-child){border-right:1px solid var(--border-color)}.toggle-btn.active{background-color:var(--primary-color);color:#fff}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state h3{margin-bottom:.5rem;color:var(--text-primary)}.checkbox-list{border:1px solid var(--border-color);border-radius:var(--radius);padding:.5rem;max-height:150px;overflow-y:auto;background-color:var(--surface-color)}.checkbox-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;border-radius:4px;transition:background-color .2s;color:var(--text-primary)}[data-theme=dark] .checkbox-item{color:var(--text-primary)}.checkbox-item:hover{background-color:var(--background-color)}.checkbox-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color)}.checkbox-item span{font-size:.875rem}.task-dropdown-item{color:var(--text-primary);transition:background-color .15s}.task-dropdown-item:hover{background-color:var(--background-color)}.mobile-hamburger,.office-hub-scroll-hint{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:4px}@media (max-width: 768px){.mobile-hamburger{display:flex;align-items:center}.office-hub-scroll-hint{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1000;width:260px;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 20px #00000026}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:#0000004d}.sidebar.collapsed{width:260px}.sidebar.collapsed .nav-label{display:inline}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:.5rem 1.5rem}.sidebar.collapsed .nav-item-nested{display:flex}.sidebar.collapsed .sidebar-header{padding:0 1.5rem 1rem;justify-content:space-between}.header{padding:.5rem 1rem}.header-user-info{display:none}.main-content{padding:.75rem}.page-header{flex-direction:column;align-items:flex-start!important;gap:.5rem}.office-hub-layout{flex-direction:column!important}.office-hub-sidebar{width:100%!important;flex-direction:row!important;flex-wrap:wrap;gap:.5rem!important}.office-hub-sidebar .card{flex:1;min-width:100px}.office-hub-canvas-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.office-hub-canvas-container{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch}.office-hub-scroll-hint{display:flex;align-items:center;gap:4px;justify-content:center;padding:4px 0;font-size:.85rem;color:var(--text-secondary)}}.rich-text>*:first-child{margin-top:0}.rich-text>*:last-child{margin-bottom:0}.rich-text p{margin:0 0 .6rem;line-height:1.5}.rich-text h1,.rich-text h2,.rich-text h3,.rich-text h4,.rich-text h5,.rich-text h6{font-size:.95rem;font-weight:600;margin:.8rem 0 .4rem}.rich-text a{color:var(--primary-color, #2563eb);text-decoration:underline}.rich-text blockquote{border-left:3px solid var(--border-color, #e2e8f0);padding:.25rem 0 .25rem .75rem;margin:.5rem 0;color:var(--text-secondary, #64748b)}.rich-text code{background:var(--bg-secondary, #f1f5f9);padding:.1rem .3rem;border-radius:3px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em}.rich-text pre{background:var(--bg-secondary, #f1f5f9);padding:.6rem;border-radius:4px;overflow-x:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em;margin:.5rem 0}.rich-text pre code{background:transparent;padding:0;border-radius:0}.rich-text ul,.rich-text ol{margin:.4rem 0 .6rem 1.5rem;padding:0}.rich-text li{margin:.2rem 0}.rich-text hr{border:none;border-top:1px solid var(--border-color, #e2e8f0);margin:.8rem 0}:root{--vh-border-soft: #eef1f5;--vh-row-hover: #fafbfc;--vh-row-open-bg: #f7f9fc;--vh-row-open-edge: #1e40af}.task-type-glyph{flex:none;display:inline-grid;place-items:center;width:22px;height:22px;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-weight:600;letter-spacing:0;position:relative;vertical-align:middle;margin-right:.5rem}.task-type-glyph-dot{position:absolute;right:-2px;bottom:-2px;width:6px;height:6px;background:#fff;border-radius:50%;box-shadow:0 0 0 1.5px currentColor}.task-status{display:inline-flex;align-items:center;gap:7px;font-size:12.5px}.task-status-dot{width:7px;height:7px;border-radius:50%;flex:none}.task-status-label{color:var(--text-primary, #0f172a);letter-spacing:-.005em}.task-actions-reveal{opacity:0;transform:translate(4px);transition:opacity .1s ease-out,transform .1s ease-out}tr:hover>td .task-actions-reveal,tr.task-row-open>td .task-actions-reveal{opacity:1;transform:none}tr.task-row-open{background:var(--vh-row-open-bg);box-shadow:inset 2px 0 0 var(--vh-row-open-edge)}.task-tree-rail{position:relative}.task-tree-rail:before{content:"";position:absolute;left:.75rem;top:-1px;height:50%;border-left:1px solid var(--vh-border-soft)}.task-tree-rail:after{content:"";position:absolute;left:.75rem;top:50%;width:14px;border-top:1px solid var(--vh-border-soft)}.task-numeric{font-variant-numeric:tabular-nums}
