@layer components{.shell-pinned-conversation{display:flex;flex-direction:column;height:100%}.shell-pinned-messages{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--shell-spacing-xs);padding:var(--shell-spacing-xs)}.shell-pinned-empty,.shell-pinned-error,.shell-pinned-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--shell-color-text-secondary);font-size:.875rem}.shell-pinned-error{color:#ef4444}.shell-pinned-message{padding:var(--shell-spacing-xs) var(--shell-spacing-sm);border-radius:var(--shell-radius-md);background:var(--shell-color-surface-hover)}.shell-pinned-message.own{background:rgba(var(--shell-color-brand-rgb,59,130,246),.1)}.shell-pinned-message-header{display:flex;align-items:center;gap:var(--shell-spacing-sm);margin-bottom:2px}.shell-pinned-message-sender{font-weight:600;font-size:.75rem;color:var(--shell-color-text)}.shell-pinned-message-time{font-size:.625rem;color:var(--shell-color-text-secondary)}.shell-pinned-message-body{font-size:.8125rem;color:var(--shell-color-text);word-break:break-word}.shell-pinned-typing{padding:var(--shell-spacing-xs) var(--shell-spacing-sm);font-size:.75rem;color:var(--shell-color-text-secondary);font-style:italic}.shell-pinned-gif-preview{display:flex;align-items:center;gap:var(--shell-spacing-sm);padding:var(--shell-spacing-sm);border-top:1px solid var(--shell-color-border)}.shell-pinned-gif-actions{display:flex;gap:var(--shell-spacing-xs)}.shell-pinned-gif-actions button{padding:var(--shell-spacing-xs) var(--shell-spacing-sm);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);background:transparent;cursor:pointer;font-size:.75rem;color:var(--shell-color-text-secondary)}.shell-pinned-gif-actions button:hover{background:var(--shell-color-surface-hover);color:var(--shell-color-text)}.shell-pinned-composer{border-top:1px solid var(--shell-color-border);padding:var(--shell-spacing-sm);position:relative}.shell-pinned-mention-picker{display:flex;flex-wrap:wrap;gap:var(--shell-spacing-xs);margin-bottom:var(--shell-spacing-xs)}.shell-pinned-mention-picker button{padding:var(--shell-spacing-xs) var(--shell-spacing-sm);background:var(--shell-color-surface-hover);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);cursor:pointer;font-size:.75rem;color:var(--shell-color-text)}.shell-pinned-mention-picker button:hover{border-color:var(--shell-color-brand)}.shell-pinned-composer-row{display:flex;gap:var(--shell-spacing-sm)}.shell-pinned-input{flex:1 1;min-height:32px;max-height:80px;padding:var(--shell-spacing-xs) var(--shell-spacing-sm);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-md);background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.8125rem;white-space:pre-wrap;overflow-y:auto;outline:none}.shell-pinned-input:focus{border-color:var(--shell-color-brand)}.shell-pinned-input:empty:before{content:attr(data-placeholder);color:var(--shell-color-text-secondary);pointer-events:none}.shell-pinned-send{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--shell-radius-md);background:var(--shell-color-brand);color:#fff;cursor:pointer;transition:all var(--shell-transition-fast)}.shell-pinned-send:hover:not(:disabled){opacity:.9}.shell-pinned-send:disabled{opacity:.5;cursor:not-allowed}.shell-calendar-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.shell-calendar-item{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);background:var(--shell-color-surface-alt)}.shell-calendar-item-main{flex:1 1;display:flex;flex-direction:column;gap:4px}.shell-calendar-title{font-weight:600;color:var(--shell-color-text)}.shell-calendar-time{font-size:.875rem;color:var(--shell-color-text-muted);display:flex;align-items:center;gap:8px}.shell-calendar-account-tag{display:inline-block;font-size:.7rem;padding:2px 6px;border-radius:var(--shell-radius-sm);background:var(--shell-surface-brand-soft);color:var(--shell-color-brand);font-weight:500;text-transform:lowercase}.shell-calendar-meta{font-size:.813rem;color:var(--shell-color-text-muted)}.shell-calendar-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end;justify-content:center;min-width:120px}.shell-calendar-btn{padding:6px 10px;border:1px solid var(--shell-color-border);background:transparent;color:var(--shell-color-text);border-radius:var(--shell-radius-sm);cursor:pointer;font-size:.813rem;transition:all var(--shell-transition-fast);text-decoration:none}.shell-calendar-btn.primary{background:var(--shell-color-brand);color:#fff}.shell-calendar-btn.primary,.shell-calendar-btn:hover:not(:disabled){border-color:var(--shell-color-brand)}.shell-calendar-btn:disabled{opacity:.6;cursor:not-allowed}.shell-calendar-notice{background:var(--shell-surface-brand-faint);color:var(--shell-color-text);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);padding:8px 12px;margin-bottom:8px;font-size:.85rem}.shell-calendar-now-indicator{display:flex;align-items:center;gap:8px;padding:6px 0;margin-bottom:4px}.shell-calendar-now-dot{width:8px;height:8px;border-radius:50%;background:var(--shell-color-brand);flex-shrink:0;animation:pulse 2s ease-in-out infinite}}@layer components{@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.shell-calendar-now-time{font-size:.75rem;font-weight:600;color:var(--shell-color-brand);flex-shrink:0}.shell-calendar-now-line{flex:1 1;height:1px;background:var(--shell-color-brand);opacity:.4}.shell-calendar-free-time{border-style:dashed!important;border-color:var(--shell-color-success,#22c55e)!important;background:rgba(34,197,94,.05)!important}.shell-calendar-free-label{gap:6px;font-size:.875rem;font-weight:500}.shell-calendar-free-icon,.shell-calendar-free-label{display:flex;align-items:center;color:var(--shell-color-success,#22c55e)}.shell-calendar-item-past{opacity:.5;background:var(--shell-color-surface)!important}.shell-calendar-item-past .shell-calendar-title{text-decoration:line-through;-webkit-text-decoration-color:var(--shell-color-text-muted);text-decoration-color:var(--shell-color-text-muted)}.shell-calendar-item-current{position:relative;border-color:var(--shell-color-brand)!important;border-width:2px;background:var(--shell-surface-brand-faint)!important}.shell-calendar-item-current:before{content:"NOW";position:absolute;top:-8px;left:12px;font-size:.65rem;font-weight:700;color:var(--shell-color-brand);background:var(--shell-color-surface);padding:0 4px;letter-spacing:.05em}.shell-calendar-countdown{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.7rem;font-weight:600;color:var(--shell-color-brand);background:var(--shell-surface-brand-soft);border-radius:10px;animation:countdown-pulse 2s ease-in-out infinite}@keyframes countdown-pulse{0%,to{opacity:1}50%{opacity:.7}}.shell-link-button{color:var(--shell-color-brand);text-decoration:underline;background:none;border:none;padding:0;cursor:pointer;font:inherit}.shell-calendar-page{display:flex;flex-direction:column;gap:var(--shell-spacing-lg);height:100%}.shell-calendar-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--shell-spacing-lg);padding:18px 20px;border:1px solid var(--shell-color-border);background:var(--shell-color-surface);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.06)}.shell-calendar-toolbar-left{display:flex;flex-direction:column;gap:8px}.shell-calendar-title-block .eyebrow{text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;color:var(--shell-color-text-muted)}.shell-calendar-title-block .title{font-size:1.3rem;font-weight:700;color:var(--shell-color-text)}.shell-calendar-controls{display:flex;align-items:center;gap:10px}.shell-calendar-nav-btns{display:flex;align-items:center;gap:8px}.shell-calendar-range{font-weight:600;color:var(--shell-color-text);letter-spacing:-.01em}.shell-calendar-toolbar-right{display:flex;align-items:center;gap:var(--shell-spacing-md)}.shell-calendar-view-switch{display:inline-flex;gap:6px;padding:4px;border-radius:999px;background:var(--shell-color-surface-alt);border:1px solid var(--shell-color-border)}.shell-calendar-pill{border:1px solid transparent;background:transparent;color:var(--shell-color-text-muted);padding:6px 12px;border-radius:999px;cursor:pointer;font-weight:600;transition:all var(--shell-transition-fast)}.shell-calendar-pill.active{background:var(--shell-color-brand);color:#fff;border-color:var(--shell-color-brand);box-shadow:0 6px 20px var(--shell-surface-brand-strong)}.shell-calendar-connection{display:flex;align-items:center;gap:10px}.shell-calendar-btn.subtle{background:var(--shell-color-surface-alt);border-style:dashed;color:var(--shell-color-text-muted)}.shell-calendar-btn.icon{width:34px;height:34px;padding:0}.shell-calendar-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,420px);grid-gap:var(--shell-spacing-lg);gap:var(--shell-spacing-lg);align-items:start}.shell-calendar-surface{border:1px solid var(--shell-color-border);background:var(--shell-color-surface);border-radius:16px;padding:16px;min-height:520px}.shell-calendar-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:10px;gap:10px}.shell-calendar-week.single{grid-template-columns:1fr}.shell-calendar-week-day{border:1px solid var(--shell-color-border);border-radius:12px;background:var(--shell-color-surface-alt);display:flex;flex-direction:column;min-height:200px}.shell-calendar-week-day-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--shell-color-border)}.shell-calendar-week-day-name{color:var(--shell-color-text-muted);font-weight:600}.shell-calendar-week-day-number{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--shell-color-text)}.shell-calendar-week-day-number.today{background:var(--shell-surface-brand-soft);color:var(--shell-color-brand);font-weight:700}.shell-calendar-week-events{flex:1 1;padding:12px;display:flex;flex-direction:column;gap:10px}.shell-calendar-event-card{border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-md);padding:10px 12px;text-align:left;background:var(--shell-color-surface);cursor:pointer;transition:all var(--shell-transition-fast)}.shell-calendar-event-card:hover{border-color:var(--shell-color-brand);transform:translateY(-2px)}.shell-calendar-event-card.selected{border-color:var(--shell-color-brand);box-shadow:0 6px 20px var(--shell-surface-brand-strong)}.shell-calendar-event-time{font-size:.85rem;color:var(--shell-color-text-muted)}.shell-calendar-event-title{font-weight:600;margin-top:2px;margin-bottom:4px}.shell-calendar-event-meta{font-size:.8rem;color:var(--shell-color-text-muted)}.shell-calendar-empty{padding:16px;text-align:center;color:var(--shell-color-text-muted)}.shell-calendar-empty.muted{padding:0;text-align:left}.shell-calendar-month{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:8px;gap:8px}.shell-calendar-month-cell{border:1px solid var(--shell-color-border);border-radius:12px;padding:8px;background:var(--shell-color-surface-alt);min-height:120px;display:flex;flex-direction:column;gap:6px}.shell-calendar-month-cell.today{border-color:var(--shell-color-brand);box-shadow:inset 0 0 0 1px var(--shell-border-brand-soft)}.shell-calendar-month-cell.muted{opacity:.5}.shell-calendar-month-day{font-weight:600;display:flex;justify-content:space-between;color:var(--shell-color-text)}.shell-calendar-month-events{display:flex;flex-direction:column;gap:6px}.shell-calendar-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;background:var(--shell-color-surface);border:1px solid var(--shell-color-border);cursor:pointer;text-align:left;transition:all var(--shell-transition-fast)}.shell-calendar-chip .dot{width:8px;height:8px;border-radius:999px;background:var(--shell-color-brand)}.shell-calendar-chip .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell-calendar-chip.selected{border-color:var(--shell-color-brand);background:var(--shell-surface-brand-weak)}.shell-calendar-more{font-size:.8rem;color:var(--shell-color-text-muted)}.shell-calendar-agenda{display:flex;flex-direction:column;gap:8px}.shell-calendar-agenda-row{display:grid;grid-template-columns:90px 1fr 80px;grid-gap:12px;gap:12px;align-items:center;border:1px solid var(--shell-color-border);border-radius:12px;padding:10px 12px;background:var(--shell-color-surface);cursor:pointer;transition:all var(--shell-transition-fast)}.shell-calendar-agenda-row.selected,.shell-calendar-agenda-row:hover{border-color:var(--shell-color-brand)}.shell-calendar-agenda-row.selected{box-shadow:0 6px 20px var(--shell-surface-brand-strong)}.shell-calendar-agenda-date{display:flex;flex-direction:column;align-items:flex-start;gap:2px;color:var(--shell-color-text-muted);font-weight:600}.shell-calendar-agenda-date .day{font-size:1.3rem;color:var(--shell-color-text)}.shell-calendar-agenda-main .title{font-weight:600}.shell-calendar-agenda-main .meta{font-size:.85rem;color:var(--shell-color-text-muted)}.shell-calendar-agenda-actions{text-align:right;color:var(--shell-color-brand);font-weight:600}.shell-calendar-context{border:1px solid var(--shell-color-border);background:var(--shell-color-surface);border-radius:16px;padding:16px;position:-webkit-sticky;position:sticky;top:12px;display:flex;flex-direction:column;gap:16px}.shell-calendar-context-header .label{font-size:.8rem;color:var(--shell-color-text-muted);letter-spacing:.03em;text-transform:uppercase}.shell-calendar-context-header .heading{font-size:1.1rem;font-weight:700;margin-top:4px}.shell-calendar-context-header .subheading{color:var(--shell-color-text-muted);margin-top:2px}.shell-calendar-context-header .meta{color:var(--shell-color-text-muted);font-size:.9rem}.shell-calendar-context-body{display:flex;flex-direction:column;gap:16px}.shell-calendar-context-block{border:1px dashed var(--shell-color-border);border-radius:12px;padding:12px;background:var(--shell-color-surface-alt)}.shell-calendar-context-block .block-title{font-weight:700;margin-bottom:8px}.shell-calendar-context-card{border:1px solid var(--shell-color-border);border-radius:12px;padding:12px;background:var(--shell-color-surface);display:flex;flex-direction:column;gap:4px}.shell-calendar-context-card .label{font-size:.8rem;color:var(--shell-color-text-muted)}.shell-calendar-context-card .title{font-weight:700}.shell-calendar-context-card p{margin:0;color:var(--shell-color-text-muted);font-size:.9rem}.shell-calendar-context-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:10px;gap:10px}.shell-calendar-blueprint{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:8px;gap:8px}.shell-calendar-blueprint li{padding:10px;border:1px solid var(--shell-color-border);border-radius:10px;background:var(--shell-color-surface)}.shell-calendar-blueprint .title{font-weight:700}.shell-calendar-blueprint .body{color:var(--shell-color-text-muted);font-size:.9rem;margin-top:4px}.shell-calendar-attachment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.shell-calendar-attachment-list li{display:flex;justify-content:space-between;align-items:center;gap:8px}.shell-calendar-attachment-list a{color:var(--shell-color-brand);font-weight:600}.shell-calendar-attachment-list .mime{font-size:.8rem;color:var(--shell-color-text-muted)}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.shell-calendar-pill.attendee{border-color:var(--shell-color-border);color:var(--shell-color-text)}.shell-calendar-pill.attendee .sub{color:var(--shell-color-text-muted);margin-left:6px;font-weight:400}@media (max-width:1100px){.shell-calendar-layout{grid-template-columns:1fr}.shell-calendar-context{position:static}.shell-calendar-toolbar{flex-direction:column}}.cal-page{display:flex;flex-direction:column;height:100%;gap:16px}.cal-toolbar{justify-content:space-between;padding:12px 16px;background:var(--shell-color-surface);backdrop-filter:var(--shell-glass-blur);-webkit-backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);border-radius:var(--shell-radius-md);flex-shrink:0;box-shadow:var(--shell-shadow-md)}.cal-toolbar,.cal-toolbar-left{display:flex;align-items:center}.cal-toolbar-left{gap:12px}.cal-toolbar-right{display:flex;align-items:center;gap:16px}.cal-nav-btn{padding:8px 16px;background:var(--shell-color-surface);border:1px solid var(--shell-color-border);border-radius:8px;color:var(--shell-color-text);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.cal-nav-btn:hover{background:var(--shell-color-surface-alt);border-color:var(--shell-color-brand)}.cal-nav-arrows{display:flex;gap:4px}.cal-nav-arrow{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--shell-color-border);border-radius:8px;color:var(--shell-color-text-muted);cursor:pointer;transition:all .15s ease}.cal-nav-arrow:hover{background:var(--shell-color-surface-alt);color:var(--shell-color-text);border-color:var(--shell-color-brand)}.cal-title{font-size:1.125rem;font-weight:600;color:var(--shell-color-text);margin:0}.cal-view-toggle{display:flex;background:var(--shell-color-surface-alt);border-radius:8px;padding:3px;gap:2px}.cal-view-btn{padding:6px 14px;background:transparent;border:none;border-radius:6px;color:var(--shell-color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.cal-view-btn.active,.cal-view-btn:hover{color:var(--shell-color-text)}.cal-view-btn.active{background:var(--shell-color-surface);box-shadow:0 1px 3px rgba(0,0,0,.1)}.cal-status{display:flex;align-items:center;gap:6px;font-size:.813rem;color:var(--shell-color-text-muted)}.cal-status-dot{width:8px;height:8px;border-radius:50%;background:var(--shell-color-text-muted)}.cal-status.connected .cal-status-dot{background:#10b981}.cal-status.disconnected .cal-status-dot{background:#f59e0b}.cal-content{display:grid;grid-template-columns:1fr 340px;grid-gap:16px;gap:16px;flex:1 1;min-height:0}.cal-main{display:flex;flex-direction:column}.cal-main,.cal-sidebar{background:var(--shell-color-surface);backdrop-filter:var(--shell-glass-blur);-webkit-backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);border-radius:var(--shell-radius-md);overflow:hidden;box-shadow:var(--shell-shadow-md)}.cal-grid-container{display:flex;flex-direction:column;height:100%}.cal-header-row{display:flex;border-bottom:1px solid var(--shell-color-border);flex-shrink:0}.cal-header-row .cal-time-gutter{width:60px;flex-shrink:0}.cal-day-header{flex:1 1;display:flex;flex-direction:column;align-items:center;padding:12px 8px;gap:4px}.cal-day-name{font-size:.75rem;font-weight:500;color:var(--shell-color-text-muted);text-transform:uppercase;letter-spacing:.03em}.cal-day-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.938rem;font-weight:600;color:var(--shell-color-text);border-radius:50%}.cal-day-number.today{background:var(--shell-color-brand);color:#fff}.cal-grid-scroll{flex:1 1;overflow-y:auto;overflow-x:hidden}.cal-grid-body{display:flex;position:relative}.cal-grid-body .cal-time-gutter{width:60px;flex-shrink:0;border-right:1px solid rgba(0,0,0,.06)}.cal-time-label{height:60px;padding:0 8px;display:flex;align-items:flex-start;justify-content:flex-end;font-size:.688rem;color:var(--shell-color-text-muted);transform:translateY(-8px)}.cal-day-column{flex:1 1;position:relative;border-right:1px solid rgba(0,0,0,.06)}.cal-day-column:last-child{border-right:none}.cal-day-column.today{background:rgba(66,133,244,.04)}.cal-time-slot{height:60px;border-bottom:1px solid rgba(0,0,0,.06);position:relative;cursor:pointer;transition:background-color .15s ease}.cal-time-slot:hover{background:var(--shell-surface-brand-hover)}.cal-time-slot.drop-target{background:var(--shell-surface-brand-soft);box-shadow:inset 0 0 0 2px var(--shell-color-brand)}.cal-time-slot:after{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:rgba(0,0,0,.03);pointer-events:none}.cal-time-slot:last-child{border-bottom:none}.cal-now-line{left:0;right:0;height:2px;z-index:10}.cal-now-line,.cal-now-line:before{position:absolute;background:#ef4444}.cal-now-line:before{content:"";left:-4px;top:-3px;width:8px;height:8px;border-radius:50%}.cal-event{position:absolute;left:4px;right:4px;padding:3px 8px;border-radius:6px;border:none;border-left:4px solid;text-align:left;cursor:-webkit-grab;cursor:grab;overflow:hidden;transition:box-shadow .15s ease,opacity .15s ease,z-index 0s;z-index:5;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none}.cal-event:hover{box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:7}.cal-event:active{cursor:-webkit-grabbing;cursor:grabbing}.cal-event.dragging{opacity:.5;box-shadow:0 4px 16px rgba(0,0,0,.2);z-index:100}.cal-event.selected{box-shadow:0 0 0 2px var(--shell-color-brand);z-index:8}.cal-event-time{font-size:.688rem;font-weight:500;color:var(--event-color,var(--shell-color-text-muted))}.cal-event-title{font-size:.813rem;font-weight:600;color:var(--shell-color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event.compact{display:flex;align-items:center;padding:2px 6px}.cal-event-compact{display:flex;align-items:baseline;min-width:0;overflow:hidden}.cal-event-compact .cal-event-title{flex-shrink:1;min-width:0}.cal-event-compact .cal-event-time{flex-shrink:0;margin-left:0}.cal-month{display:flex;flex-direction:column;height:100%}.cal-month-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--shell-color-border)}.cal-month-day-name{padding:12px;text-align:center;font-size:.75rem;font-weight:500;color:var(--shell-color-text-muted);text-transform:uppercase;letter-spacing:.03em}.cal-month-grid{display:grid;grid-template-columns:repeat(7,1fr);flex:1 1}.cal-month-cell{border-right:1px solid var(--shell-color-border);border-bottom:1px solid var(--shell-color-border);padding:8px;min-height:100px}.cal-month-cell:nth-child(7n){border-right:none}.cal-month-cell.muted{background:var(--shell-color-surface-alt)}.cal-month-cell.muted .cal-month-date{color:var(--shell-color-text-muted)}.cal-month-cell.today .cal-month-date{background:var(--shell-color-brand);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.cal-month-date{font-size:.813rem;font-weight:500;color:var(--shell-color-text);margin-bottom:4px}.cal-month-events{display:flex;flex-direction:column;gap:2px}.cal-month-event{display:flex;align-items:center;gap:6px;padding:2px 6px;background:transparent;border:none;border-radius:4px;cursor:pointer;text-align:left;transition:background .15s ease}.cal-month-event:hover{background:var(--shell-color-surface-alt)}.cal-month-event.selected{background:var(--shell-surface-brand-weak)}.cal-month-event .dot{width:6px;height:6px;border-radius:50%;background:var(--dot-color,var(--shell-color-brand));flex-shrink:0}.cal-month-event .label{font-size:.75rem;color:var(--shell-color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-month-more{font-size:.688rem;color:var(--shell-color-text-muted);padding:2px 6px}.cal-agenda{display:flex;flex-direction:column;gap:2px;padding:12px}.cal-agenda-item{display:flex;align-items:center;gap:12px;padding:12px;background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;text-align:left;transition:all .15s ease}.cal-agenda-item.selected,.cal-agenda-item:hover{background:var(--shell-color-surface-alt)}.cal-agenda-item.selected{border-color:var(--shell-color-brand)}.cal-agenda-date{width:48px;text-align:center;flex-shrink:0}.cal-agenda-date .day{display:block;font-size:1.5rem;font-weight:600;color:var(--shell-color-text);line-height:1}.cal-agenda-date .month{display:block;font-size:.75rem;color:var(--shell-color-text-muted);text-transform:uppercase}.cal-agenda-indicator{width:3px;height:40px;border-radius:2px;flex-shrink:0}.cal-agenda-content{flex:1 1;min-width:0}.cal-agenda-content .title{font-weight:500;color:var(--shell-color-text)}.cal-agenda-content .meta,.cal-agenda-content .title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-agenda-content .meta{font-size:.813rem;color:var(--shell-color-text-muted)}.cal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;min-height:300px;color:var(--shell-color-text-muted)}.cal-loading-spinner{width:24px;height:24px;border:2px solid var(--shell-color-border);border-top-color:var(--shell-color-brand);border-radius:50%;animation:cal-spin .8s linear infinite}@keyframes cal-spin{to{transform:rotate(1turn)}}.cal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;min-height:300px;color:var(--shell-color-text-muted);text-align:center;padding:24px}.cal-btn{padding:8px 16px;background:var(--shell-color-surface);border:1px solid var(--shell-color-border);border-radius:8px;color:var(--shell-color-text);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.cal-btn.primary{background:var(--shell-color-brand);border-color:var(--shell-color-brand);color:#fff}.cal-btn.primary:hover{filter:brightness(1.1)}.cal-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;min-height:300px;padding:24px;text-align:center;color:var(--shell-color-text-muted)}.cal-detail-empty-icon{color:var(--shell-color-border)}.cal-detail{display:flex;flex-direction:column;gap:16px;padding:20px}.cal-detail-header{padding-left:12px;border-left:3px solid var(--shell-color-brand)}.cal-detail-title{font-size:1.125rem;font-weight:600;color:var(--shell-color-text);line-height:1.3}.cal-detail-time{font-size:.938rem;color:var(--shell-color-text);margin-top:4px}.cal-detail-date{font-size:.875rem;color:var(--shell-color-text-muted);margin-top:2px}.cal-join-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#10b981;border:none;border-radius:8px;color:#fff;font-weight:500;font-size:.875rem;text-decoration:none;transition:all .15s ease}.cal-join-btn:hover{filter:brightness(1.1)}.cal-detail-section{display:flex;flex-direction:column;gap:8px}.cal-detail-section-title{font-size:.75rem;font-weight:600;color:var(--shell-color-text-muted);text-transform:uppercase;letter-spacing:.03em}.cal-detail-location{font-size:.875rem;color:var(--shell-color-text)}.cal-attendees{display:flex;flex-direction:column;gap:8px}.cal-attendee{display:flex;align-items:center;gap:10px}.cal-attendee-avatar{width:32px;height:32px;border-radius:50%;background:var(--shell-color-surface-alt);border:1px solid var(--shell-color-border);display:flex;align-items:center;justify-content:center;font-size:.813rem;font-weight:600;color:var(--shell-color-text-muted);flex-shrink:0}.cal-attendee-info .name{font-size:.875rem;font-weight:500;color:var(--shell-color-text)}.cal-attendee-info .email{font-size:.75rem;color:var(--shell-color-text-muted)}.cal-attendee-more{font-size:.813rem;color:var(--shell-color-text-muted);padding-left:42px}.cal-attachments{display:flex;flex-direction:column;gap:6px}.cal-attachment{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--shell-color-surface-alt);border:1px solid var(--shell-color-border);border-radius:6px;color:var(--shell-color-text);font-size:.875rem;text-decoration:none;transition:all .15s ease}.cal-attachment:hover{border-color:var(--shell-color-brand);color:var(--shell-color-brand)}.cal-detail-account{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--shell-color-text)}.cal-account-dot{width:8px;height:8px;border-radius:50%}.cal-open-link{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:transparent;border:1px dashed var(--shell-color-border);border-radius:8px;color:var(--shell-color-text-muted);font-size:.813rem;text-decoration:none;transition:all .15s ease}.cal-open-link:hover{border-color:var(--shell-color-brand);color:var(--shell-color-brand)}.cal-detail-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--shell-color-border)}.cal-action-btn{flex:1 1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:1px solid var(--shell-color-border);border-radius:8px;background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.cal-action-btn:hover{border-color:var(--shell-color-brand);color:var(--shell-color-brand)}.cal-action-btn.danger{color:#ef4444}.cal-action-btn.danger:hover{border-color:#ef4444;background:rgba(239,68,68,.1)}.cal-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cal-modal{background:var(--shell-color-surface);border:1px solid var(--shell-color-border);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.3)}.cal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--shell-color-border)}.cal-modal-title{font-size:1.125rem;font-weight:600;color:var(--shell-color-text)}.cal-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--shell-color-text-muted);cursor:pointer;transition:all .15s ease}.cal-modal-close:hover{background:var(--shell-color-surface-alt);color:var(--shell-color-text)}.cal-modal-body{padding:20px;gap:16px}.cal-form-group,.cal-modal-body{display:flex;flex-direction:column}.cal-form-group{gap:6px}.cal-form-label{font-size:.813rem;font-weight:500;color:var(--shell-color-text-muted)}.cal-form-input{padding:10px 12px;border:1px solid var(--shell-color-border);border-radius:8px;background:var(--shell-color-surface-alt);color:var(--shell-color-text);font-size:.875rem;outline:none;transition:all .15s ease}.cal-form-input:focus{border-color:var(--shell-color-brand);box-shadow:0 0 0 3px var(--shell-surface-brand-weak)}.cal-form-input::placeholder{color:var(--shell-color-text-muted)}.cal-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.cal-form-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer}.cal-form-checkbox input{width:16px;height:16px;accent-color:var(--shell-color-brand)}.cal-form-checkbox span{font-size:.875rem;color:var(--shell-color-text)}.cal-modal-footer{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--shell-color-border)}.cal-modal-btn{flex:1 1;padding:10px 16px;border:1px solid var(--shell-color-border);border-radius:8px;background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.cal-modal-btn:hover{background:var(--shell-color-surface-alt)}.cal-modal-btn.primary{background:var(--shell-color-brand);border-color:var(--shell-color-brand);color:#fff}.cal-modal-btn.primary:hover{background:var(--shell-color-brand-hover,#5855eb)}.cal-modal-btn:disabled{opacity:.5;cursor:not-allowed}.cal-account-select{padding:10px 12px;border:1px solid var(--shell-color-border);border-radius:8px;background:var(--shell-color-surface-alt);color:var(--shell-color-text);font-size:.875rem;outline:none;cursor:pointer}.cal-account-select:focus{border-color:var(--shell-color-brand)}.cal-create-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--shell-color-brand);border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.cal-create-btn:hover{background:var(--shell-color-brand-hover,#5855eb)}.cal-create-btn svg{width:16px;height:16px}.cal-confirm-text{font-size:.875rem;line-height:1.5}.cal-confirm-text,.cal-confirm-text strong{color:var(--shell-color-text)}.cal-modal-btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}.cal-modal-btn.danger:hover{background:#dc2626}@media (max-width:1024px){.cal-content{grid-template-columns:1fr}.cal-sidebar{order:-1}}@media (max-width:768px){.cal-toolbar{flex-direction:column;gap:12px;align-items:stretch}.cal-toolbar-left,.cal-toolbar-right{justify-content:space-between}.cal-title{font-size:1rem}}}@layer components{.projects-page{flex-direction:column}.projects-header,.projects-page{display:flex;gap:var(--shell-spacing-lg)}.projects-header{align-items:flex-start;justify-content:space-between;padding:var(--shell-spacing-xl);background:var(--shell-color-surface);backdrop-filter:var(--shell-glass-blur);-webkit-backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);color:var(--shell-color-text);border-radius:var(--shell-radius-md);box-shadow:var(--shell-shadow-md)}.projects-header h1{margin:6px 0;font-size:24px}.projects-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:12px}.projects-kicker,.projects-subtext{color:var(--shell-color-text-muted)}.projects-subtext{max-width:640px}.projects-actions{display:flex;gap:var(--shell-spacing-sm)}.projects-btn{border:1px solid var(--shell-color-border-strong);background:var(--shell-color-surface);color:var(--shell-color-text);padding:10px 14px;border-radius:var(--shell-radius-sm);font-weight:600;cursor:pointer;transition:all var(--shell-transition-fast)}.projects-btn:hover:not(:disabled){border-color:var(--shell-color-brand);color:var(--shell-color-brand)}.projects-btn:disabled{opacity:.5;cursor:not-allowed}.projects-btn.primary{background:var(--projects-color-accent);border-color:var(--projects-color-accent);color:#fff}.projects-btn.primary:hover:not(:disabled){background:var(--projects-color-accent-hover);border-color:var(--projects-color-accent-hover)}.projects-tabs{display:inline-flex;gap:6px;padding:4px;background:var(--shell-color-surface);border-radius:var(--shell-radius-md);border:1px solid var(--shell-glass-border)}.projects-tab{border:none;background:transparent;color:var(--shell-color-text-muted);padding:10px 14px;border-radius:var(--shell-radius-sm);cursor:pointer;font-weight:600;transition:all var(--shell-transition-fast)}.projects-tab:hover{color:var(--shell-color-text)}.projects-tab.active{background:var(--shell-surface-brand-soft);color:var(--shell-color-brand)}.projects-content{display:flex;flex-direction:column;gap:var(--shell-spacing-lg)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:var(--shell-spacing-md);gap:var(--shell-spacing-md)}.projects-card{background:var(--shell-color-surface);backdrop-filter:var(--shell-glass-blur);-webkit-backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);border-radius:var(--shell-radius-md);padding:var(--shell-spacing-lg);color:var(--shell-color-text);display:flex;flex-direction:column;gap:var(--shell-spacing-sm);box-shadow:var(--shell-shadow-md);transition:border-color var(--shell-transition-fast),box-shadow var(--shell-transition-fast),transform var(--shell-transition-fast)}.projects-card:hover{border-color:rgba(var(--projects-color-accent-rgb),.5);box-shadow:var(--shell-shadow-lg);transform:translateY(-2px)}.projects-card-link{text-decoration:none;color:inherit;cursor:pointer}.projects-card-title{font-weight:700;color:var(--shell-color-text)}.projects-muted{color:var(--shell-color-text-muted);line-height:1.5}.projects-list{margin:0;padding-left:18px;color:var(--shell-color-text);display:grid;grid-gap:var(--shell-spacing-xs);gap:var(--shell-spacing-xs)}.projects-stack{display:flex;flex-direction:column;gap:var(--shell-spacing-md)}.projects-updates-header{display:flex;align-items:center;justify-content:space-between}.projects-updates-list{display:flex;flex-direction:column;gap:var(--shell-spacing-md)}.projects-update-card{background:var(--shell-color-surface);backdrop-filter:var(--shell-glass-blur);-webkit-backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);border-radius:var(--shell-radius-md);padding:var(--shell-spacing-lg);color:var(--shell-color-text);display:flex;flex-direction:column;gap:var(--shell-spacing-sm);box-shadow:var(--shell-shadow-md)}.projects-update-card.pinned{border-color:var(--projects-color-accent);box-shadow:0 0 0 1px rgba(var(--projects-color-accent-rgb),.35)}.projects-update-title-row{display:flex;align-items:center;gap:var(--shell-spacing-sm);flex-wrap:wrap}.projects-update-title{font-weight:700;font-size:16px}.projects-update-meta{color:var(--shell-color-text-muted);display:flex;align-items:center;gap:6px}.projects-update-body{color:var(--shell-color-text);line-height:1.5}.projects-comments-placeholder{padding:10px 12px;border:1px dashed var(--shell-color-border);border-radius:var(--shell-radius-sm);color:var(--shell-color-text-muted)}.projects-status{padding:4px 8px;border-radius:var(--shell-radius-full);font-weight:700;font-size:12px;text-transform:uppercase}.projects-status.green{background:var(--projects-status-active-bg);color:var(--projects-status-active)}.projects-status.yellow{background:var(--projects-status-warning-bg);color:var(--projects-status-warning)}.projects-status.red{background:var(--projects-status-danger-bg);color:var(--projects-status-danger)}.projects-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--shell-radius-full);background:var(--shell-color-surface-elevated);color:var(--shell-color-text);border:1px solid var(--shell-color-border);font-weight:600;font-size:12px}.projects-pill-row{display:flex;gap:var(--shell-spacing-sm);flex-wrap:wrap}.projects-program-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;background:var(--shell-surface-brand-soft);color:var(--shell-color-brand);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.025em;margin-bottom:4px}.projects-programs-header-top{display:flex;align-items:center;justify-content:space-between;gap:var(--shell-spacing-lg);margin-bottom:var(--shell-spacing-sm)}.projects-archive-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--shell-color-text-muted);cursor:pointer}.projects-archive-toggle input{width:14px;height:14px;accent-color:var(--shell-color-brand);cursor:pointer}.projects-archive-toggle:hover{color:var(--shell-color-text)}.projects-archived-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;background:var(--shell-surface-neutral-strong);color:var(--shell-color-text-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.projects-card.archived{opacity:.7}.projects-card.archived:hover{opacity:.9}.projects-dot{color:var(--shell-color-text-muted)}.projects-updates-list .projects-update-card:last-child{margin-bottom:4px}.projects-update-top{display:flex;flex-direction:column;gap:var(--shell-spacing-xs)}.projects-card-actions{display:inline-flex;gap:var(--shell-spacing-md);margin-top:var(--shell-spacing-xs)}.projects-link{color:var(--projects-color-accent);text-decoration:none;font-weight:600}.projects-link:hover{text-decoration:underline}.projects-link.danger{color:var(--shell-color-negative)}.projects-programs{display:flex;flex-direction:column;gap:var(--shell-spacing-md)}.projects-programs-header{display:flex;align-items:center;justify-content:space-between}.projects-chip{border:1px solid var(--shell-color-border);background:var(--shell-color-surface);color:var(--shell-color-text);border-radius:var(--shell-radius-full);padding:6px 12px;cursor:pointer;font-weight:600;transition:all var(--shell-transition-fast)}.projects-chip.active{border-color:var(--projects-color-accent);color:var(--projects-color-accent);box-shadow:0 0 0 1px rgba(var(--projects-color-accent-rgb),.25)}.projects-list-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--shell-spacing-md);gap:var(--shell-spacing-md)}.projects-card-title-row{display:flex;align-items:center;justify-content:space-between}.projects-meta-row{display:flex;gap:var(--shell-spacing-sm);flex-wrap:wrap}.projects-project-card .projects-link{margin-top:var(--shell-spacing-sm)}.projects-comments,.projects-comments-list{display:flex;flex-direction:column;gap:var(--shell-spacing-sm)}.projects-comment{padding:10px 12px;border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);background:var(--shell-color-surface)}.projects-comment-header{display:flex;align-items:center;justify-content:space-between;color:var(--shell-color-text-muted);font-size:12px}.projects-comment-author{font-weight:700;color:var(--shell-color-text)}.projects-comment-body{margin-top:var(--shell-spacing-xs);color:var(--shell-color-text);line-height:1.4}.projects-comment-composer{display:flex;align-items:center;gap:var(--shell-spacing-sm)}.projects-input{flex:1 1;padding:10px 12px;border-radius:var(--shell-radius-sm);border:1px solid var(--shell-color-border);background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.875rem;transition:border-color var(--shell-transition-fast),box-shadow var(--shell-transition-fast)}.projects-input:focus{outline:none;border-color:var(--shell-color-border-focus);box-shadow:0 0 0 3px rgba(var(--shell-color-brand-rgb),.15)}.projects-select{padding:10px 12px;border-radius:var(--shell-radius-sm);border:1px solid var(--shell-color-border);background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.875rem;cursor:pointer;transition:border-color var(--shell-transition-fast)}.projects-select:focus{outline:none;border-color:var(--shell-color-border-focus)}.projects-textarea{width:100%;padding:10px 12px;border-radius:var(--shell-radius-sm);border:1px solid var(--shell-color-border);background:var(--shell-color-surface);color:var(--shell-color-text);font-size:.875rem;resize:vertical;transition:border-color var(--shell-transition-fast),box-shadow var(--shell-transition-fast)}.projects-textarea:focus{outline:none;border-color:var(--shell-color-border-focus);box-shadow:0 0 0 3px rgba(var(--shell-color-brand-rgb),.15)}.projects-form{gap:10px}.projects-field{display:flex;flex-direction:column;gap:6px}.projects-label{font-weight:600;color:var(--shell-color-text);font-size:13px}.projects-checkbox{display:inline-flex;align-items:center;gap:var(--shell-spacing-sm)}.projects-inline-actions{display:flex;justify-content:flex-end;gap:var(--shell-spacing-sm);margin-top:var(--shell-spacing-xs)}.projects-error{color:var(--shell-color-negative);font-size:13px}.projects-btn.small{padding:8px 12px;font-size:12px}.projects-btn.danger{color:var(--shell-color-negative);border-color:var(--shell-color-negative)}.projects-btn.danger:hover:not(:disabled){background:var(--shell-color-negative);color:#fff}.projects-task-list{display:flex;flex-direction:column;gap:var(--shell-spacing-sm)}.projects-task-row{padding:var(--shell-spacing-md);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);background:var(--shell-color-surface);display:flex;flex-direction:column;gap:6px}.projects-task-main{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--shell-spacing-md)}.projects-task-title{font-weight:700;color:var(--shell-color-text)}.projects-task-meta{display:flex;gap:6px;flex-wrap:wrap}.projects-timeline{display:flex;flex-direction:column;gap:10px;position:relative}.projects-timeline:before{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:var(--shell-color-border)}.projects-timeline-row{display:flex;align-items:flex-start;gap:var(--shell-spacing-md);position:relative;padding-left:20px}.projects-timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--projects-color-accent);position:absolute;left:4px;top:6px}.projects-timeline-content{display:flex;flex-direction:column;gap:var(--shell-spacing-xs)}.projects-timeline-date{color:var(--shell-color-text-muted);font-size:12px}.projects-timeline-title{color:var(--shell-color-text);font-weight:700}[data-theme=light] .projects-status.green{color:var(--shell-color-positive)}[data-theme=light] .projects-status.yellow{color:#a16207}[data-theme=light] .projects-status.red{color:var(--shell-color-negative)}.projects-breadcrumb{display:flex;align-items:center;gap:var(--shell-spacing-sm);font-size:.875rem;margin-bottom:var(--shell-spacing-sm)}.projects-breadcrumb-link{color:var(--projects-color-accent);text-decoration:none;transition:color var(--shell-transition-fast)}.projects-breadcrumb-link:hover{color:var(--projects-color-accent-hover);text-decoration:underline}.projects-breadcrumb-current,.projects-breadcrumb-sep{color:var(--shell-color-text-muted)}.projects-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--shell-z-modal)}.projects-modal{background:var(--shell-color-surface-elevated);-webkit-backdrop-filter:var(--shell-glass-blur);backdrop-filter:var(--shell-glass-blur);border:1px solid var(--shell-glass-border);border-radius:var(--shell-radius-lg);padding:var(--shell-spacing-xl);max-width:400px;width:90%;flex-direction:column;box-shadow:var(--shell-shadow-lg)}.projects-card-header,.projects-modal{display:flex;gap:var(--shell-spacing-md)}.projects-card-header{align-items:center;justify-content:space-between}.projects-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--shell-spacing-md);gap:var(--shell-spacing-md)}}@layer components{@media (max-width:600px){.projects-form-row{grid-template-columns:1fr}}.projects-select-inline{width:auto;min-width:120px;padding:4px 8px;font-size:.75rem}.projects-save-feedback{font-size:.75rem;padding:4px 8px;border-radius:4px;font-weight:500}.projects-save-feedback.saved{background:var(--projects-status-active-bg);color:var(--projects-status-active)}.projects-save-feedback.error{background:var(--projects-status-danger-bg);color:var(--projects-status-danger)}[data-theme=light] .projects-save-feedback.saved{color:var(--shell-color-positive)}[data-theme=light] .projects-save-feedback.error{color:var(--shell-color-negative)}.projects-overview-details{flex-direction:column}.projects-detail-row,.projects-overview-details{display:flex;gap:var(--shell-spacing-md)}.projects-detail-label{font-size:12px;color:var(--shell-color-text-muted);min-width:80px;flex-shrink:0}.projects-detail-value{font-size:13px;color:var(--shell-color-text)}.projects-title-row{display:flex;align-items:center;gap:var(--shell-spacing-md)}.projects-status-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:var(--shell-radius-md);text-transform:uppercase;letter-spacing:.5px}.projects-status-badge.status-green{background:var(--projects-status-active-bg);color:var(--projects-status-active)}.projects-status-badge.status-blue{background:rgba(59,130,246,.2);color:#3b82f6}.projects-status-badge.status-yellow{background:var(--projects-status-warning-bg);color:var(--projects-status-warning)}.projects-status-badge.status-gray{background:var(--shell-surface-neutral-strong);color:var(--shell-color-text-muted)}[data-theme=light] .projects-status-badge.status-green{color:var(--shell-color-positive)}[data-theme=light] .projects-status-badge.status-blue{color:#2563eb}[data-theme=light] .projects-status-badge.status-yellow{color:#ca8a04}.projects-pinned-update{display:flex;gap:var(--shell-spacing-md);align-items:flex-start}.projects-status-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}.projects-status-dot.green{background:var(--projects-status-active)}.projects-status-dot.yellow{background:var(--projects-status-warning)}.projects-status-dot.red{background:var(--projects-status-danger)}.projects-pinned-content{flex:1 1}.projects-pinned-title{font-weight:600;font-size:14px;color:var(--shell-color-text)}.projects-pinned-meta{font-size:12px;color:var(--shell-color-text-muted);margin-top:2px}.projects-pinned-body{margin-top:var(--shell-spacing-sm);font-size:13px;line-height:1.5}.projects-empty-state{display:flex;flex-direction:column;gap:var(--shell-spacing-md)}.projects-quick-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--shell-spacing-sm);gap:var(--shell-spacing-sm)}.projects-action-btn{display:flex;align-items:center;gap:var(--shell-spacing-sm);padding:10px 12px;border-radius:var(--shell-radius-sm);background:var(--shell-surface-neutral-weak);border:1px solid var(--shell-color-border);color:var(--shell-color-text);font-size:13px;cursor:pointer;transition:all var(--shell-transition-fast)}.projects-action-btn:hover{background:var(--shell-surface-neutral-soft);border-color:var(--shell-color-border-strong)}.projects-action-icon{font-size:14px}.projects-btn-link{background:none;border:none;color:var(--shell-color-brand);font-size:13px;cursor:pointer;padding:0}.projects-btn-link:hover{text-decoration:underline}.overview-empty,.projects-card-header-right{display:flex;align-items:center;gap:var(--shell-spacing-md)}.overview-empty{flex-direction:column;padding:var(--shell-spacing-lg);text-align:center}.task-detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--shell-z-modal);padding:var(--shell-spacing-lg)}.task-detail-modal{width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:taskModalSlideIn .2s ease-out}@keyframes taskModalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.task-detail-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--shell-spacing-md);border-bottom:1px solid var(--shell-color-border);margin-bottom:var(--shell-spacing-lg)}.task-detail-header-left{display:flex;align-items:center;gap:var(--shell-spacing-sm)}.task-detail-status-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.task-detail-status-icon{font-size:10px}.task-detail-overdue-badge{font-size:11px}.task-detail-close{background:none;border:none;color:var(--shell-color-text-muted);cursor:pointer;padding:8px;border-radius:var(--shell-radius-sm);transition:all var(--shell-transition-fast);display:flex;align-items:center;justify-content:center}.task-detail-close:hover{background:var(--shell-surface-neutral-soft);color:var(--shell-color-text)}.task-detail-content{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--shell-spacing-xl);padding-right:var(--shell-spacing-xs)}.task-detail-title-section{margin-bottom:var(--shell-spacing-sm)}.task-detail-title-input,.task-detail-title-input input{font-size:1.25rem;font-weight:600}.task-detail-title-input input{border:none;background:transparent;padding:0}.task-detail-title-input input:focus{box-shadow:none;border-bottom:2px solid var(--shell-color-brand);border-radius:0}.task-detail-quick-info{display:flex;flex-wrap:wrap;gap:var(--shell-spacing-lg);padding:var(--shell-spacing-md) var(--shell-spacing-lg);background:var(--shell-surface-neutral-hint);border-radius:var(--shell-radius-md);border:1px solid var(--shell-color-border)}.task-detail-quick-item{display:flex;flex-direction:column;gap:4px;min-width:100px}.task-detail-quick-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--shell-color-text-muted)}.task-detail-assignee-preview{display:flex;align-items:center;gap:var(--shell-spacing-sm);font-size:13px;color:var(--shell-color-text)}.task-detail-avatar{width:24px;height:24px;border-radius:50%;background:var(--shell-gradient-brand);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center}.task-detail-due-date{font-size:13px;color:var(--shell-color-text);font-weight:500}.task-detail-due-date.overdue{color:var(--shell-color-negative)}.task-detail-section{display:flex;flex-direction:column;gap:var(--shell-spacing-md)}.task-detail-section-title{display:flex;align-items:center;gap:var(--shell-spacing-sm);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--shell-color-text-muted);margin:0}.task-detail-section-title svg{color:var(--shell-color-text-muted);opacity:.7}.task-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--shell-spacing-md);gap:var(--shell-spacing-md)}.task-detail-timeline-grid{display:grid;grid-template-columns:1fr 1fr 120px;grid-gap:var(--shell-spacing-md);gap:var(--shell-spacing-md)}@media (max-width:600px){.task-detail-grid,.task-detail-timeline-grid{grid-template-columns:1fr}}.task-detail-deps-list,.task-detail-field{display:flex;flex-direction:column}.task-detail-deps-list{gap:var(--shell-spacing-xs)}.task-detail-dep-item{display:flex;align-items:center;gap:var(--shell-spacing-sm);padding:var(--shell-spacing-sm) var(--shell-spacing-md);background:var(--shell-surface-neutral-hint);border:1px solid var(--shell-color-border);border-radius:var(--shell-radius-sm);font-size:13px}.task-detail-dep-icon{color:var(--shell-color-negative);font-size:14px}.task-detail-dep-title{flex:1 1;color:var(--shell-color-text)}.task-detail-dep-remove{background:none;border:none;color:var(--shell-color-text-muted);cursor:pointer;padding:4px;border-radius:var(--shell-radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--shell-transition-fast)}.task-detail-dep-remove:hover{background:var(--shell-surface-neutral-soft);color:var(--shell-color-negative)}.task-detail-add-dep{margin-top:var(--shell-spacing-sm)}.task-detail-empty-text{font-size:13px;color:var(--shell-color-text-muted);font-style:italic}.task-detail-checklist{display:flex;flex-direction:column;gap:var(--shell-spacing-sm)}.task-detail-checklist-item{display:flex;align-items:center;gap:var(--shell-spacing-sm);padding:var(--shell-spacing-sm) 0}.task-detail-checkbox{width:18px;height:18px;border:2px solid var(--shell-color-border-strong);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--shell-transition-fast)}.task-detail-checkbox.checked{background:var(--shell-color-positive);border-color:var(--shell-color-positive);color:#fff}.task-detail-checklist-text{font-size:14px;color:var(--shell-color-text)}.task-detail-checklist-text.completed{text-decoration:line-through;color:var(--shell-color-text-muted)}.task-detail-required{color:var(--shell-color-negative);margin-left:2px}.task-detail-error{display:flex;align-items:center;gap:var(--shell-spacing-sm);padding:var(--shell-spacing-md);background:var(--projects-status-danger-bg);border:1px solid var(--projects-status-danger);border-radius:var(--shell-radius-sm);color:var(--projects-status-danger);font-size:13px;margin-top:var(--shell-spacing-md)}[data-theme=light] .task-detail-error{color:var(--shell-color-negative)}.task-detail-footer{display:flex;justify-content:flex-end;gap:var(--shell-spacing-sm);padding-top:var(--shell-spacing-lg);margin-top:var(--shell-spacing-lg);border-top:1px solid var(--shell-color-border)}.task-detail-content::-webkit-scrollbar{width:6px}.task-detail-content::-webkit-scrollbar-track{background:transparent}.task-detail-content::-webkit-scrollbar-thumb{background:var(--shell-color-border-strong);border-radius:3px}.task-detail-content::-webkit-scrollbar-thumb:hover{background:var(--shell-color-text-muted)}}