*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f1f5f9;color:#1e293b;height:100vh;overflow:hidden;font-size:15px}#root{display:flex;height:100vh}.sidebar{width:260px;min-width:260px;background:#1e293b;color:#e2e8f0;display:flex;flex-direction:column;padding:0;overflow-y:auto}.sidebar-logo{padding:24px 20px 20px;font-size:1.2rem;font-weight:700;color:#f8fafc;border-bottom:1px solid #334155;display:flex;align-items:center;gap:10px}.sidebar-logo span{font-size:1.6rem}.sidebar-nav{padding:10px 0;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 20px;cursor:pointer;border-radius:0;font-size:1rem;color:#94a3b8;transition:background .15s,color .15s;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:#334155;color:#f1f5f9}.nav-item.active{background:#3b82f6;color:#fff}.nav-item .icon{font-size:1.25rem;width:26px;text-align:center}.sidebar-members{padding:16px 20px;border-top:1px solid #334155}.sidebar-members h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin-bottom:10px}.member-chip{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.95rem;color:#cbd5e1}.member-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px}.topbar h1{font-size:1.3rem;font-weight:700;color:#1e293b}.topbar-nav{display:flex;align-items:center;gap:10px}.btn{padding:8px 18px;border-radius:8px;border:none;font-size:.92rem;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#f1f5f9;color:#475569}.btn-secondary:hover{background:#e2e8f0}.btn-ghost{background:none;color:#64748b;border:1px solid #e2e8f0}.btn-ghost:hover{background:#f8fafc}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:4px 10px;font-size:.8rem}.btn-icon{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:6px;font-size:1rem;color:#64748b}.btn-icon:hover{background:#f1f5f9}.content{flex:1;overflow-y:auto;padding:28px 32px}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:20px}.card+.card{margin-top:16px}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0;border-radius:12px;overflow:hidden}.month-header-cell{background:#f8fafc;padding:12px 6px;text-align:center;font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase}.month-cell{background:#fff;min-height:130px;padding:6px}.month-cell.other-month{background:#f8fafc}.month-cell.today .day-num{background:#3b82f6;color:#fff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.day-num{font-size:.95rem;font-weight:600;color:#374151;width:30px;height:30px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.month-event{font-size:.78rem;padding:3px 7px;border-radius:5px;margin-bottom:2px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.week-day{background:#fff;border-radius:12px;padding:14px;min-height:160px}.week-day.today{border:2px solid #3b82f6}.week-day-header{font-size:.88rem;font-weight:600;color:#64748b;margin-bottom:8px}.week-day-header .date-num{font-size:1.5rem;color:#1e293b;display:block}.week-event{font-size:.82rem;padding:4px 8px;border-radius:6px;margin-bottom:4px;color:#fff;cursor:pointer}.day-timeline{display:flex;flex-direction:column;gap:0}.time-row{display:flex;min-height:64px;border-top:1px solid #f1f5f9}.time-label{width:70px;font-size:.82rem;color:#94a3b8;padding:6px 10px 0 0;text-align:right;flex-shrink:0}.time-slot{flex:1;padding:4px 6px;position:relative}.day-event{font-size:.9rem;padding:6px 10px;border-radius:8px;margin-bottom:4px;color:#fff;cursor:pointer}.task-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:10px;transition:background .1s}.task-item:hover{background:#f8fafc}.task-item.done .task-title{text-decoration:line-through;color:#94a3b8}.task-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6;flex-shrink:0}.task-title{flex:1;font-size:.95rem}.task-meta{font-size:.75rem;color:#94a3b8}.priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.priority-high{background:#ef4444}.priority-normal{background:#3b82f6}.priority-low{background:#94a3b8}.reminder-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px}.reminder-item:hover{background:#f8fafc}.reminder-item.done .reminder-title{text-decoration:line-through;color:#94a3b8}.reminder-title{flex:1;font-size:.9rem}.quick-add{display:flex;gap:8px;margin-top:12px}.quick-add input{flex:1;padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;outline:none}.quick-add input:focus{border-color:#3b82f6}.filter-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.filter-tab{padding:5px 12px;border-radius:20px;font-size:.82rem;cursor:pointer;border:1px solid #e2e8f0;background:#fff;color:#64748b;transition:all .15s}.filter-tab.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center}.modal{background:#fff;border-radius:16px;padding:28px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto}.modal h2{font-size:1.1rem;font-weight:700;margin-bottom:20px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.82rem;font-weight:600;color:#475569;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-family:inherit;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-actions{display:flex;gap:8px;margin-top:20px;justify-content:flex-end}.member-chips{display:flex;flex-wrap:wrap;gap:6px}.member-chip-select{padding:4px 10px;border-radius:20px;font-size:.8rem;cursor:pointer;border:2px solid transparent;transition:all .15s;background:#f1f5f9;color:#475569}.member-chip-select.selected{color:#fff}.member-admin-row{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:10px;margin-bottom:8px}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid #e2e8f0;cursor:pointer;flex-shrink:0}.color-picker-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.color-option{width:24px;height:24px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:border .1s}.color-option.selected{border-color:#1e293b}.today-badge{background:#dbeafe;color:#1d4ed8;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#1e293b;z-index:50;padding:0;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-inner{display:flex;height:56px}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:.6rem;gap:2px;cursor:pointer;border:none;background:none;transition:color .15s}.bottom-nav-item.active{color:#60a5fa}.bottom-nav-item .bn-icon{font-size:1.3rem}@media (max-width: 768px){body{overflow:hidden}.sidebar{display:none}.bottom-nav{display:flex}.main{padding-bottom:56px}.topbar{padding:0 12px}.topbar h1{font-size:1rem}.content{padding:12px 12px 72px}.week-grid{grid-template-columns:repeat(7,minmax(90px,1fr));overflow-x:auto}.month-cell{min-height:60px}.month-event{font-size:.65rem}.day-timeline{font-size:.85rem}.chore-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.modal{width:100%;max-width:100%;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:90vh}.modal-backdrop{align-items:flex-end}.card{padding:14px}.btn{padding:8px 16px;font-size:.9rem}.btn-sm{padding:6px 12px;font-size:.82rem}.task-checkbox{width:22px;height:22px}.filter-tabs{gap:4px}.filter-tab{font-size:.78rem;padding:4px 10px}}
