*,:before,:after{box-sizing:border-box}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:#e2e8f0;background:#0f1117;margin:0}#root{width:100%;min-height:100vh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e2e8f0;background:#0f1117;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{flex-direction:column;max-width:1400px;min-height:100vh;margin:0 auto;padding:0 16px 48px;display:flex}.app-header{border-bottom:1px solid #1e2533;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 0 16px;display:flex}.header-left{align-items:center;gap:14px;display:flex}.logo-mark{letter-spacing:.5px;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:800;display:flex}.app-title{color:#f1f5f9;font-size:20px;font-weight:700;line-height:1.2}.app-subtitle{color:#64748b;margin-top:2px;font-size:13px}.member-selector{flex-shrink:0;align-items:center;gap:10px;display:flex}.selector-label{color:#94a3b8;white-space:nowrap;font-size:13px}.search-container{position:relative}.member-input{color:#e2e8f0;background:#1e2533;border:1px solid #2d3748;border-radius:8px;outline:none;width:220px;padding:8px 12px;font-size:14px;transition:border-color .2s}.member-input:focus{border-color:#6366f1}.member-input::placeholder{color:#475569}.member-dropdown{z-index:100;background:#1a2135;border:1px solid #2d3748;border-radius:8px;min-width:220px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.dropdown-item{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:9px 12px;font-size:14px;transition:background .1s;display:flex}.dropdown-item:hover{background:#243047}.dropdown-item.add-new{color:#818cf8;border-top:1px solid #2d3748}.dropdown-empty{color:#475569;padding:9px 12px;font-size:13px}.member-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.selected-member-wrap{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.gcal-status{padding-left:2px;font-size:11px}.gcal-connected{color:#34d399;background:#0f1f17;border:1px solid #34d399;border-radius:20px;align-items:center;gap:5px;padding:3px 8px;font-size:12px;display:inline-flex}.gcal-connected svg{filter:grayscale(0)opacity(.85);flex-shrink:0;width:14px;height:14px}.gcal-connect{color:#818cf8;cursor:pointer;text-decoration:none}.gcal-connect:hover{text-decoration:underline}.selected-member{background:#1e2533;border:1px solid #2d3748;border-radius:8px;align-items:center;gap:8px;padding:7px 12px;font-size:14px;display:flex}.member-name{color:#e2e8f0;font-weight:500}.change-btn{color:#64748b;cursor:pointer;background:0 0;border:none;padding:0 0 0 4px;font-size:12px;text-decoration:underline}.change-btn:hover{color:#94a3b8}.week-nav{justify-content:center;align-items:center;gap:16px;padding:16px 0 10px;display:flex}.nav-btn{color:#94a3b8;cursor:pointer;background:#1e2533;border:1px solid #2d3748;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;line-height:1;transition:background .15s,color .15s;display:flex}.nav-btn:hover{color:#e2e8f0;background:#2d3748}.week-info{align-items:center;gap:10px;display:flex}.week-label{color:#e2e8f0;text-align:center;min-width:200px;font-size:15px;font-weight:600}.this-week-btn{color:#818cf8;cursor:pointer;background:0 0;border:1px solid #3b4a6b;border-radius:6px;padding:3px 8px;font-size:12px;transition:background .15s}.this-week-btn:hover{background:#1e2d4d}.zoom-control{align-items:center;gap:6px;margin-left:12px;display:flex}.zoom-icon{color:#475569;-webkit-user-select:none;user-select:none;font-size:14px;line-height:1}.zoom-slider{appearance:none;cursor:pointer;background:#2d3748;border-radius:2px;outline:none;width:80px;height:4px}.zoom-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#6366f1;border-radius:50%;width:14px;height:14px;transition:background .15s}.zoom-slider::-webkit-slider-thumb:hover{background:#818cf8}.zoom-slider::-moz-range-thumb{cursor:pointer;background:#6366f1;border:none;border-radius:50%;width:14px;height:14px}.status-bar{color:#86efac;background:#0d2818;border:1px solid #166534;border-radius:8px;align-items:center;gap:8px;margin:6px 0;padding:8px 14px;font-size:13px;display:flex}.status-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.zoom-link{color:#86efac;font-weight:600}.instruction-banner{color:#64748b;background:#111827;border:1px solid #1e2d3d;border-radius:8px;align-items:center;gap:8px;margin:6px 0;padding:8px 14px;font-size:13px;display:flex}.instruction-banner.active{color:#94a3b8;background:#1a1f35;border-color:#3b4a6b}.member-dot-inline{border-radius:50%;flex-shrink:0;width:9px;height:9px;display:inline-block}.error-banner{color:#fca5a5;background:#2d1515;border:1px solid #7f1d1d;border-radius:8px;margin:6px 0;padding:10px 14px;font-size:13px}.legend{flex-wrap:wrap;gap:12px;padding:8px 0;display:flex}.legend-item{color:#94a3b8;align-items:center;gap:6px;font-size:13px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.calendar-container{background:#111827;border:1px solid #1e2533;border-radius:12px;flex:1;margin-top:8px;overflow:hidden}.loading{color:#475569;justify-content:center;align-items:center;height:200px;font-size:15px;display:flex}.calendar-wrapper{flex-direction:column;display:flex;overflow-x:auto}.calendar-header{z-index:10;background:#111827;border-bottom:2px solid #1e2533;grid-template-columns:52px repeat(7,1fr);display:grid;position:sticky;top:0}.day-header{text-align:center;color:#64748b;letter-spacing:.3px;text-transform:uppercase;border-left:1px solid #1e2533;padding:10px 6px;font-size:12px;font-weight:600}.day-header.today{color:#818cf8}.calendar-body{grid-template-columns:52px repeat(7,1fr);min-height:400px;max-height:calc(100vh - 280px);display:grid;overflow-y:auto}.time-gutter{border-right:1px solid #1e2533;position:relative}.time-label{color:#334155;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:10px;position:absolute;right:6px;transform:translateY(-50%)}.day-col{border-left:1px solid #1e2533;position:relative;overflow:visible}.day-col.today-col{background:#6366f108}.day-col.droppable{cursor:crosshair}.day-col.droppable:hover{background:#6366f10a}.hour-line,.half-hour-line{pointer-events:none;position:absolute;left:0;right:0}.hour-line{border-top:1px solid #1e2533}.half-hour-line{border-top:1px dashed #151d2d}.commitment-block{cursor:pointer;z-index:2;border-radius:5px;flex-direction:column;justify-content:flex-start;gap:1px;padding:3px 6px;transition:opacity .1s,transform .1s;display:flex;position:absolute;left:3px;right:3px;overflow:hidden}.commitment-block:hover{z-index:3;transform:scale(1.01)}.block-name{color:#fffffff2;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;line-height:1.3;overflow:hidden}.block-time{color:#ffffffb3;white-space:nowrap;text-overflow:ellipsis;font-size:10px;line-height:1.2;overflow:hidden}.drag-ghost{z-index:5;cursor:default!important}.now-indicator{z-index:4;pointer-events:none;align-items:center;display:flex;position:absolute;left:0;right:0;transform:translateY(-50%)}.now-dot{background:#ef4444;border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-left:-4px}.now-line{opacity:.8;background:#ef4444;flex:1;height:2px}.commitment-block.menu-open{z-index:3;transform:scale(1.02)}.block-menu{-webkit-user-select:none;user-select:none;background:#1a2135;border:1px solid #2d3748;border-radius:10px;min-width:210px;overflow:hidden;box-shadow:0 12px 32px #00000080}.block-menu-header{align-items:center;gap:10px;padding:12px 14px 10px;display:flex}.block-menu-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.block-menu-info{flex-direction:column;gap:2px;display:flex}.block-menu-name{color:#f1f5f9;font-size:13px;font-weight:700}.block-menu-time{color:#64748b;font-size:11px}.block-menu-divider{background:#2d3748;height:1px;margin:0}.block-menu-item{cursor:pointer;color:#cbd5e1;text-align:left;background:0 0;border:none;flex-wrap:wrap;align-items:center;gap:8px;width:100%;padding:10px 14px;font-size:13px;transition:background .12s;display:flex}.block-menu-item:hover{background:#243047}.block-menu-item.join{color:#86efac}.block-menu-item.join:hover{background:#0d2818}.block-menu-item.delete{color:#fca5a5}.block-menu-item.delete:hover{background:#2d1515}.block-menu-item.disabled{color:#475569;cursor:default;font-size:12px}.block-menu-item.disabled:hover{background:0 0}.block-menu-item.small{padding-top:6px;padding-bottom:8px;font-size:11px}.menu-icon{opacity:.8;flex-shrink:0;font-size:12px}.menu-sub{color:#4ade80;opacity:.8;margin-left:auto;font-size:11px}.header-right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.tz-switcher{background:#1e2533;border:1px solid #2d3748;border-radius:8px;flex-shrink:0;align-items:center;display:flex;overflow:hidden}.tz-btn{color:#64748b;cursor:pointer;letter-spacing:.3px;background:0 0;border:none;padding:6px 10px;font-size:12px;font-weight:600;transition:background .12s,color .12s}.tz-btn:hover{color:#94a3b8;background:#2d3748}.tz-btn.active{color:#fff;background:#6366f1}.tz-note{color:#475569;white-space:nowrap;margin-left:auto;font-size:11px}.legend-row{flex-wrap:wrap;align-items:flex-start;gap:16px;padding:4px 0;display:flex}.legend-fixed{border-left:1px solid #1e2533;padding-left:16px}.legend-dot-fixed{border-radius:50%;flex-shrink:0;width:10px;height:10px}.fixed-event-block{z-index:1;pointer-events:none;opacity:.82;border-radius:5px;flex-direction:column;justify-content:flex-start;gap:1px;padding:3px 6px;display:flex;position:absolute;left:3px;right:3px;overflow:hidden}.fixed-event-block .block-name{color:#fffffff2}.fixed-event-block .block-time{color:#ffffffbf}.fixed-event-block.fixed-event-clickable{pointer-events:auto;cursor:pointer}.fixed-event-block.fixed-event-clickable:hover{opacity:1;filter:brightness(1.15)}.personal-event-block{z-index:0;pointer-events:none;background:#64748b2e;border-left:2px solid #94a3b866;border-radius:4px;flex-direction:column;gap:1px;padding:3px 6px;display:flex;position:absolute;left:3px;right:3px;overflow:hidden}.personal-event-block .block-name{color:#94a3b8bf;font-size:10px;font-weight:500}.personal-event-block .block-time{color:#64748bb3;font-size:9px}.block-link{color:#ffffffa6;white-space:nowrap;text-overflow:ellipsis;text-underline-offset:2px;margin-top:1px;font-size:9px;text-decoration:underline;overflow:hidden}.commit-popup{z-index:100;background:#1a2135;border:1px solid #2d3748;border-radius:12px;flex-direction:column;gap:12px;width:240px;padding:14px;display:flex;position:fixed;box-shadow:0 16px 40px #0009}.commit-popup-header{align-items:center;gap:8px;display:flex}.commit-popup-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.commit-popup-name{color:#f1f5f9;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:700;overflow:hidden}.commit-popup-close{color:#475569;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 2px;font-size:18px;line-height:1}.commit-popup-close:hover{color:#94a3b8}.commit-popup-date{color:#64748b;margin-top:-4px;font-size:12px}.commit-popup-times{align-items:center;gap:10px;display:flex}.commit-popup-times label{flex-direction:column;flex:1;gap:4px;display:flex}.commit-popup-times label span{color:#64748b;text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600}.commit-popup-times input[type=time]{color:#f1f5f9;background:#111827;border:1px solid #2d3748;border-radius:6px;outline:none;width:100%;padding:5px 7px;font-size:13px}.commit-popup-times input[type=time]:focus{border-color:#6366f1}.commit-popup-actions{gap:8px;margin-top:2px;display:flex}.commit-popup-cancel{color:#64748b;cursor:pointer;background:0 0;border:1px solid #2d3748;border-radius:8px;flex:1;padding:8px 0;font-size:13px;font-weight:600;transition:background .12s,color .12s}.commit-popup-cancel:hover{color:#94a3b8;background:#243047}.commit-popup-confirm{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;flex:1;padding:8px 0;font-size:13px;font-weight:700;transition:background .12s,opacity .12s}.commit-popup-confirm:hover:not(:disabled){background:#818cf8}.commit-popup-confirm:disabled{opacity:.35;cursor:not-allowed}.gcal-prompt-overlay{z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.gcal-prompt{text-align:center;background:#1a1f2e;border:1px solid #2d3748;border-radius:16px;width:100%;max-width:380px;padding:28px 28px 24px;box-shadow:0 20px 60px #0009}.gcal-prompt-icon{margin-bottom:12px;font-size:36px}.gcal-prompt h2{color:#f1f5f9;margin-bottom:8px;font-size:18px;font-weight:700}.gcal-prompt p{color:#94a3b8;margin-bottom:22px;font-size:14px;line-height:1.5}.gcal-prompt-actions{flex-direction:column;gap:10px;display:flex}.gcal-prompt-connect{color:#fff;background:#6366f1;border-radius:10px;padding:12px;font-size:14px;font-weight:700;text-decoration:none;transition:background .15s;display:block}.gcal-prompt-connect:hover{background:#818cf8}.gcal-prompt-skip{color:#64748b;cursor:pointer;background:0 0;border:none;padding:4px;font-size:13px;transition:color .12s}.gcal-prompt-skip:hover{color:#94a3b8}
